开发express模板引擎
发布于 8 年前 作者 zengming00 3428 次浏览 来自 分享

翻译自http://expressjs.com/en/advanced/developing-template-engines.html 2016/9/25 22:39 使用app.engine(ext, callback)方法来创建你的模板引擎,ext是指文件扩展名,callback是模板引擎程序,他接受下面这些参数 文件的路径,options 对象和回调函数 下面的代码是一个例子,实现了一个非常简单的模板引擎,渲染 .ntl 文件

var fs = require('fs'); // 这个引擎需要fs模块
app.engine('ntl', function (filePath, options, callback) { // 定义模板引擎
  fs.readFile(filePath, function (err, content) {
    if (err) return callback(new Error(err));
    // 这是一个非常简单的模板引擎
    var rendered = content.toString().replace('#title#', '<title>'+ options.title +'</title>')
    .replace('#message#', '<h1>'+ options.message +'</h1>');
    return callback(null, rendered);
  });
});
app.set('views', './views'); // 指定views文件夹
app.set('view engine', 'ntl'); // 注册模板引擎

你的app将能够处理 .ntl 文件, 创建一个 index.ntl 在views文件夹中 输入以下内容

#title#
#message#

然后,创建在你的app中创建下面的路由

app.get('/', function (req, res) {
  res.render('index', { title: 'Hey', message: 'Hello there!'});
});

当你向主页发出请求时, index.ntl 将渲染为HTML

1 回复

可以有。虽然现有的几个模板都挺好用的。不过自己写还是挺酷的

回到顶部