本文探讨了在 ejs 模板中高效渲染多个变量的方法。针对直接在单个 `` 标签内使用逗号分隔无法奏效的问题,教程详细介绍了如何利用 javascript 模板字面量(template literals)实现多变量的整合输出,从而提高模板代码的简洁性和可读性。
在 EJS (Embedded JavaScript) 模板中,我们经常需要将后端传递的数据渲染到 HTML 页面上。通常,通过 res.render() 方法将一个对象作为数据传递给 EJS 模板。例如:
// 后端代码 (Node.js/Express)
app.get('/', (req, res) => {
const currentDay = "Monday";
const typeOfDay = "Workday";
res.render('index', {
currentDay: currentDay,
typeOfDay: typeOfDay
});
});在 EJS 模板 (index.ejs) 中,我们可以通过 语法来渲染这些变量。最直接的方法是为每个变量使用单独的脚本标签:
Today is <%= currentDay%>. It's a <%= typeOfDay %>
这种方法能够正确地将 currentDay 和 typeOfDay 的值分别渲染出来,输出结果为
有时,开发者可能希望在同一个 脚本标签内渲染多个变量,以求代码更简洁。一个常见的尝试是使用逗号分隔变量:
Today is <%= currentDay, typeOfDay%>
然而,这种写法并不能达到预期的效果。在 JavaScript 表达式中,逗号运算符会依次计算每个操作数,并返回最后一个操作数的值。因此,currentDay, typeOfDay 这个表达式最终会返回 typeOfDay 的值。EJS 引擎在处理 标签时,会执行其内部的 JavaScript 表达式并将结果输出。这意味着,上述代码可能只会渲染 typeOfDay 的值,或者由于语法不符合 EJS 的标准用法而导致其他不可预测的行为,并不能将两个变量连接起来。
为了在单个 EJS 脚本标签内优雅地渲染和组合多个变量,我们可以利用 JavaScript ES6 引入的模板字面量 (Template Literals)。模板字面量使用反引号 (`) 包裹,并允许通过 ${expression} 语法嵌入表达式或变量。
将这个特性与 EJS 结合,我们可以在 标签内部构建一个模板字面量字符串,如下所示:
Today is <%= `${currentDay}, ${typeOfDay}` %>
工作原理:
这样,输出结果将是
注意事项:
在 EJS 模板中渲染多个变量时,虽然可以为每个变量使用单独的 标签,但为了提高代码的简洁性和可读性,推荐使用 JavaScript 模板字面量。通过在单个 标签内部利用反引号和 ${} 语法,我们可
以高效、优雅地组合和输出多个动态数据,从而构建出更清晰、更易维护的模板代码。