19

我正在尝试处理 Peepcode 的 Node.js Full Stack 视频,似乎他们使用的是旧版本的 express/jade。没有提到使用块/扩展来渲染布局。

应用程序中使用的设置是为所有子应用程序加载一个 /views/layout.jade 文件。子应用的视图位于 /apps//views。

我的 server.js 看起来很标准。Express 是 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'));
});

我的子应用程序的路由文件位于 /apps/authentication/routes

路线.咖啡

routes = (app) ->

  app.get "/login", (req,res) ->
    res.render "#{__dirname}/views/login",
      title: "Login"
      stylesheet: 'login'

module.exports = routes

我打算为此渲染的视图。

登录.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:3000/login 会呈现以下内容:

Express 500 错误:/Users/StevenNunez/code/HotPie/apps/authentication/views/login.jade:1 > 1| 扩展布局 2| 3| 阻止内容 4| form(action='/sessions', method='post') 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

感谢您的时间。

4

3 回答 3

19

看起来我只需要在extends调用中给出相对路径。

extends ../../../views/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')

我不必设置app.set('view options',{layout:false});

于 2012-07-26T20:54:01.190 回答
6

您可以使用变量__dirname来连接来自其他目录的视图。

例子:

app.get('/otherurl/' , (req, res) => { 
  res.render(`${__dirname}/../other_project/views/index`) 
});
于 2013-06-21T06:09:22.363 回答
2

您正在尝试使用两种渲染方法...第一个布局扩展布局,第二个是块内容。使用布局时,您将自动扩展login.jade.

没有必要使用extends也不能使用block句子,但是如果你想使用extends你必须禁用布局。

将此添加到应用程序:

app.set('view options',{layout:false});

app.set('view engine', 'jade');

并扩展文件,如布局扩展:

布局.jade

doctype 5
html
  head
    title= title
    link(rel='stylesheet', href='/stylesheets/#{stylesheet}.css')
  body
    block content

登录.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')

登录文件必须在同一个目录中。如果你想调用其他布局,你可以像这样使用目录:

appDirectory
  views
    layout
  otherViews
    login

登录.jade

extends ../views/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')
于 2012-07-26T19:12:27.470 回答