我知道很久以前就有人问过这个问题,但没有人在这篇文章中给出答案。所以我会在这里这样做。为了确保每个人都在同一页面上,我的回答会很冗长。如果它看起来过于简单,我提前道歉。
在您的 server.js 文件(或 app.js,您将把手定义为视图引擎的任何位置)中。根据您使用的 npm 包,例如 hbs 或 express-handlebars 等,它可能看起来不同,但与此类似。注意:我在这个例子中使用了快速车把。
文件:server.js
...
var express = require( 'express'),
hbs = require( 'express-handlebars' ),
app = express();
...
app.engine( 'hbs', hbs( {
extname: 'hbs',
defaultLayout: 'main',
layoutsDir: __dirname + '/views/layouts/',
partialsDir: __dirname + '/views/partials/'
} ) );
app.set( 'view engine', 'hbs' );
...
你的文件结构应该是这样的:
| /views/
|--- /layouts/
|----- main.hbs
|--- /partials/
|----- header.hbs
|----- footer.hbs
|----- ... etc.
|--- index.hbs
| server.js
您的 main.hbs 文件应如下所示:
文件:main.hbs
...
{{> header }}
...
<span> various other stuff </span>
...
{{> footer }}
要表示部分,请使用以下语法:{{> partialsNames }}
.