1. 前言
模板引擎是一种工具或库,用于在开发中生成动态内容的 HTML 页面。它通过将预定义的模板与数据结合,生成最终的输出(如 HTML 页面、字符串等)。模板引擎广泛应用于前端和后端开发,尤其是在构建动态网站时。
2. EJS模板引擎
EJS (Embedded JavaScript Templates) 是一种模板引擎,可以帮助我们在 HTML 页面中嵌入 JavaScript 代码,用于动态渲染内容。EJS 语法简洁且与 HTML 高度相似,是 Express.js 等服务器端框架的常用选择。
在项目中安装EJS
npm install ejs
模板引擎是分离用户界面和业务数据的一种技术
在Express中配置EJS为模板引擎
const express = require("express");
const app = express();
// 设置模板引擎为 EJS
app.set("view engine", "ejs");
// 设置模板文件目录(默认是 ./views)
app.set("views", "./views"); //模板引擎文件都存储在该文件夹中
// 配置静态文件目录
app.use(express.static("public"));
app.listen(3000, () => console.log("Server running at http://localhost:3000"));
3. express中使用ejs
模板引擎是一种工具,用于将数据与 HTML 模板结合,从而动态生成网页内容。模板引擎的主要功能是通过嵌入动态数据(如从数据库中获取的数据)生成静态的 HTML 页面。
npm install ejs
设置模板引擎
使用 app.set('view engine', 'ejs')
告诉 Express 使用 EJS 作为模板引擎。
app.set('view engine','ejs')
在node.js中也不仅仅只有ejs模板引擎,例如pug,twing等模板引擎
设置视图文件路径
Express默认会从views文件夹查找视图模板文件
app.set('views',path.resolve(...))
也可以指定一个自定义的文件夹路径来存放视图文件,而不是使用默认的 views
文件夹。
渲染路由
创建路由设置render响应,render()传入参数模板的文件路径,会在views文件夹中查找,以及对应数据,数据以键值对的形式传递
app.get('/home',(req,res)=>{
let title = 'hahahahahaha'
//res.render('模板的文件路径','数据')
res.render('home',{title})
})
{ username: "Alice" }
示例:渲染模板
const express = require('express');
const path = require('path');
const app = express();
// 设置视图文件夹路径和模板引擎
app.set('views', path.resolve(__dirname, 'views'));
app.set('view engine', 'ejs');
// 渲染视图,并传递数据
app.get('/', (req, res) => {
const data = { title: 'Hello EJS', message: 'Welcome to EJS!' };
res.render('index', data); // 将 data 对象传递给 'index.ejs'
});
// 启动服务器
app.listen(3000, () => {
console.log('Server is running on http://localhost:3000');
});
4. EJS模板语法
EJS 提供了许多功能来动态地生成 HTML 内容。以下是常用的 EJS 语法。
(1) 插值
EJS 允许在 HTML 中插入 JavaScript 变量。通过 <%= %>
标签可以把变量插入到页面中。
可以理解为在<%= %>标签中书写JS语句
const data = { title: 'Hello EJS', message: 'Welcome to EJS!' };
<h1><%= title %></h1> <!-- 输出 title 的值 -->
<p><%= message %></p> <!-- 输出 message 的值 -->
最终渲染的结果是:
<h1>Hello EJS</h1>
<p>Welcome to EJS!</p>
基于独立的HTML数据渲染:
<h1>Welcome, <%= username %>!</h1>
app.get("/", (req, res) => {
res.render("index", { username: "Alice" });
});
通过键值对的形式传递变量
示例:
const ejs = require("ejs");
console.log("EJS 模块加载成功");
let china = '国家';
console.log("变量定义成功");
let result = ejs.render('我爱你 <%= country %>', { country: china });
console.log("模板渲染成功");
console.log(result);
ejs.render对字符串模板进行渲染
模板 '我爱你 <%= country%>'
中的 <%= country %>
是 EJS 的插值语法,用于插入数据
{ country: china }
是传入的数据对象,键 country 的值为 '中国'
模板引擎会用传入对象中的 china
值替换模板中的 <%= country %>
(2) 输出未经转义的 HTML
如果想要在页面中输出,不经过转义的HTML,(例如,插入一些 HTML 标签
<h2>Welcome</h2>
可以使用 <%- %>
语法
<%- htmlContent %> <!-- 输出 htmlContent 中的内容,不进行转义 -->
(3) 插入语法
<%%>中可插入js语法而不影响原有标签形式
如果users数组如下:
const users = [{ name: 'Alice' }, { name: 'Bob' }];
<ul>
<% users.forEach(function(user) { %>
<li><%= user.name %></li>
<% }) %>
</ul>
<%%>中插入js语法,意为遍历fruits数组, 针对遍历后的每一个数据,插入至标签<li>中
5. Express-generator 快速构建Express项目
Express-generator是一个方便的工具,用于快速生成基于 Express 框架的项目骨架结构。它通过命令行生成一个初始项目,包含基本的目录结构、模板文件和配置文件,开发者可以在此基础上快速开始开发。
npm install -g express-generator
生成项目
使用express命令生成一个项目,并指定使用EJS作为模板引擎:
express my-app --view=ejs
my-app
是项目名称,你可以更改为你喜欢的名字。--view=ejs
表示选择EJS
作为模板引擎
安装依赖
cd my-app
npm install
所生成的结构目录如下所示:
my-app/
├── app.js // 应用入口文件
├── bin/
│ └── www // 启动脚本
├── public/ // 静态文件目录 (CSS, JS, 图片等)
│ ├── images/
│ ├── javascripts/
│ └── stylesheets/
├── routes/ // 路由文件
│ ├── index.js // 默认路由
│ └── users.js // 用户相关路由
├── views/ // EJS 模板文件目录
│ ├── error.ejs // 错误页面模板
│ └── index.ejs // 首页模板
├── package.json // 项目依赖和配置信息
└── README.md // 项目说明文件
运行项目
启动开发服务器:
npm start