【发布时间】:2018-11-16 05:54:39
【问题描述】:
我有一个 index.js 文件和一个 list.ejs 文件,我告诉 express 文件包括:
index.js:
const express = require("express");
const app = express();
app.set("view engine", "ejs"); //Express Template Engine = embedded js
app.set("views", __dirname + "\\views");
let varToUseInEJS = 5;
app.get("/", (req, res) => {
console.log("Path of Request: " + req.path);
res.render("list");
});
app.listen(8080, "localhost", 1, () => {
console.log("Example app listening on: 127.0.0.1:8080");
})
list.ejs:
<!DOCTYPE html>
<html>
<body>
<table>
<tr>
<th>Number</th>
</tr>
<% for(let i = 1; i < varToUseInEJS; i++) { %>
<tr>
<td>
<%= i %>
</td>
</tr>
<% } %>
</table>
</body>
</html>
当我将“varToUseInEJS”更改为例如 5 时,它可以工作并显示一个带有 1 到 5 + 标题的表,但在这种情况下,node.js 调试器给了我以下错误:
>> 9| <% for(let i = 1; i < varToUseInEJS; i++) { %>
10| <tr>
11| <td>
12| <%= i %>
varToUseInEJS is not defined
有没有办法让所有 .js 文件的变量对 ejs 文件自动可见?
提前感谢您的帮助。
【问题讨论】:
-
如果要将数据传递到模板变量中,请将对象作为
res.render的第二个参数传递 - 参见the docs。
标签: javascript node.js express ejs template-engine