PeepcodeのNode.js Full Stackビデオで作業しようとしています。彼らはexpress/jadeの古いバージョンを使用しているようです。 block/extendsを使ってレイアウトをレンダリングすることについての言及はありません。翡翠 - 別のディレクトリからテンプレートをロードする
アプリで使用される設定は、すべてのサブアプリケーション用に読み込まれる/views/layout.jadeファイルを持つことです。サブアプリケーションのビューは/ apps //ビューにあります。
私のserver.jsはかなり標準的です。 Expressは、私がレンダリングにいきビュー
routes.coffee
routes = (app) ->
app.get "/login", (req,res) ->
res.render "#{__dirname}/views/login",
title: "Login"
stylesheet: 'login'
module.exports = routes
認証/ルート/サブアプリケーションのための私のルートファイルがに/アプリのあるバージョン3.0.0rc1
require('coffee-script');
var express = require('express')
, http = require('http')
, path = require('path');
var app = express();
app.configure(function(){
app.set('port', process.env.PORT || 3000);
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));
});
app.configure('development', function(){
app.use(express.errorHandler());
});
require('./apps/authentication/routes')(app)
http.createServer(app).listen(app.get('port'), function(){
console.log("Express server listening on port " + app.get('port'));
});
ですこの。
login.jade
extends layout
block content
form(action='/sessions', method='post')
label
| Username
input(type='text', name='user')
label
| Password
input(type='password', name='password)
input(type='submit', name='Submit')
、最終的にレイアウト。
doctype 5
html
head
title= title
link(rel='stylesheet', href='/stylesheets/#{stylesheet}.css')
body
block content
はlocalhostに行く:
エクスプレス 500エラー:3000 /ログインはこのレンダリング/Users/StevenNunez/code/HotPie/apps/authentication/views/login.jade:1> 1 |レイアウト2 | 3 | | ENOENT、そのようなファイルやディレクトリはありません '/Users/StevenNunez/code/HotPie/apps/authentication/views/layout.jade'
私のフォルダ構造:フォーム(アクション= '/セッション'、メソッド= '投稿'
.
├── '
├── apps
│ └── authentication
│ ├── routes.coffee
│ └── views
│ └── login.jade
├── package.json
├── public
├── server.js
└── views
├── index.jade
└── layout.jade
ありがとうございます。
ok ...それはうまくいきます...しかし、拡張メソッドで動作する正しい方法であるため、アプリケーションを設定しました – andrescabana86
私は同じチュートリアルを通して働いています同じ問題。何らかの理由で、私は 'extends ../../../views/layout'を使用するのが快適ではありません。これに代わる方法はありますか? – Feech
驚くばかりです。正確に私が必要なもの! – Hcabnettek