可以使用 app.engine(ext, callback)
方法创建自己的模板引擎。ext
表示文件扩展名,而 callback
表示模板引擎函数,它接受以下项作为参数:文件位置、选项对象和回调函数。
以下代码示例实现非常简单的模板引擎以呈现 .ntl
文件。
var fs = require('fs'); // this engine requires the fs module
app.engine('ntl', function (filePath, options, callback) { // define the template engine
fs.readFile(filePath, function (err, content) {
if (err) return callback(new Error(err));
// this is an extremely simple template engine
var rendered = content.toString().replace('#title#', ''+ options.title +' ')
.replace('#message#', ''+ options.message +'
');
return callback(null, rendered);
});
});
app.set('views', './views'); // specify the views directory
app.set('view engine', 'ntl'); // register the template engine
应用程序现在能够呈现 .ntl
文件。在 views
目录中创建名为 index.ntl
且包含以下内容的文件:
#title#
#message#
然后,在应用程序中创建以下路径:
app.get('/', function (req, res) {
res.render('index', { title: 'Hey', message: 'Hello there!'});
});
您向主页发出请求时,index.ntl
将呈现为 HTML。