这个翻译StrongLoop / IBM提供.

相对于英文版的文档,本文档可能已过时。要了解最近的更新,请参阅英文版文档

将模板引擎用于 Express

在 Express 可以呈现模板文件之前,必须设置以下应用程序设置:

然后安装对应的模板引擎 npm 包:

$ npm install pug --save

与 Express 兼容的模板引擎(例如 Pug)导出名为 __express(filePath, options, callback) 的函数,该函数由 res.render() 函数调用以呈现模板代码。 某些模板引擎并不遵循此约定。Consolidate.js 库通过映射所有流行的 Node.js 模板引擎来遵循此约定,因此可以在 Express 内无缝工作。

在设置视图引擎之后,不必指定该引擎或者在应用程序中装入模板引擎模块;Express 在内部装入此模块,如下所示(针对以上示例)。


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

views 目录中创建名为 index.pug 的 Pug 模板文件,其中包含以下内容:


html
  head
    title= title
  body
    h1= message

随后创建路由以呈现 index.pug 文件。如果未设置 view engine 属性,必须指定 view 文件的扩展名。否则,可以将其忽略。


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

向主页发出请求时,index.pug 文件将呈现为 HTML。

要了解有关模板引擎在 Express 中如何工作的更多信息,请参阅:“为 Express 开发模板引擎”