0

好的,所以我是表达、模板和后端的新手。我一直在寻找一整天来回答这个问题,但无济于事。所以,我想我会在这里问。

除了在hogan-expressnode.jsexpress应用程序中声明的全局模板之外,您如何为特定路由使用不同的模板?我仍然想使用部分,所以如果你指的是我尝试不同的框架或其他东西,请记住这一点。(虽然不确定部分有多常见......)

编码

这是我从文档本身查看 Hogan-express 的代码(它已从 coffescript 转换为常规 javascript。)

var express = require('express');

var app = express();

// start example code from docs.  
// I use code like this in my app.js/server.js file

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

app.set('layout', 'layout'); // the global template as I explained above.

app.set('partials', {
  foo: 'foo'
});

app.enable('view cache');

app.engine('html', require('hogan-express'));

// I have this function referenced from a different file...
// in my code I'll explain below.

app.get('/', function(req, res) {
  res.locals = {
    name: 'Andrew'
  };
  return res.render('template', {
    partials: {
      message: 'message'
    }
  });
});

我的代码不同如下

// in---file---> 'app.js'

var routes = require('./routes/index.js');

app.get('/', routes.index);

// ---in---file---> '/routes/index.js'

exports.index =  function(req,res){

    var template_data = {
        posts : blogposts, 
        currentUser : req.user
    };

    res.render('index.html', template_data);  
};
4

1 回答 1

0

您可以将layout:'layout2'作为第二个参数发送到的 template_data 对象添加到res.render.

// in---file---> 'app.js'

var routes = require('./routes/index.js');

app.get('/', routes.index);

// ---in---file---> '/routes/index.js'

exports.index =  function(req,res){

    var template_data = {
        layout:'layout2', // this is the important addition.
        posts : blogposts, 
        currentUser : req.user
    };

    res.render('index.html', template_data);  
};

新布局将适用于您在其中声明的每条路线,但不会覆盖未以这种方式声明的其他路线的全局模板。

于 2014-04-22T08:37:06.617 回答