node+express+ejs使用模版引擎做的一个示例demo

发布时间 - 2026-01-11 03:17:41    点击率:

什么是模板引擎

模板引擎(Template Engine)是一个将页面模板和要显示的数据结合起来生成 HTML 页面的工具。如果说上面讲到的 express 中的路由控制方法相当于 MVC 中的控制器的话,那模板引擎就相当于 MVC 中的视图。

模板引擎的功能是将页面模板和要显示的数据结合起来生成 HTML 页面。它既可以运 行在服务器端又可以运行在客户端,大多数时候它都在服务器端直接被解析为 HTML,解析完成后再传输给客户端,因此客户端甚至无法判断页面是否是模板引擎生成的。有时候模板引擎也可以运行在客户端,即浏览器中,典型的代表就是 XSLT,它以 XML 为输入,在客户端生成 HTML 页面。但是由于浏览器兼容性问题,XSLT 并不是很流行。目前的主流还是由服务器运行模板引擎。

在 MVC 架构中,模板引擎包含在服务器端。控制器得到用户请求后,从模型获取数据,调用模板引擎。模板引擎以数据和页面模板为输入,生成 HTML 页面,然后返回给控制器,由控制器交回客户端。

前端常用的有哪些模板引擎

一、jade

jade是超高性能的node JavaScript模板引擎,有着非常强大的API和大量杰出的特性。它主要针对node的服务端。

二、EJS

EJS是模板引擎的一种,也是我们这个教程中使用的模板引擎,因为它使用起来十分简单,而且与 express 集成良好。

三、Handlebars

Handlebars 是 JavaScript 一个语义模板库,通过对view和data的分离来快速构建Web模板。它采用"Logic-less template"(无逻辑模版)的思路,在加载时被预编译,而不是到了客户端执行到代码时再去编译, 这样可以保证模板加载和运行的速度。Handlebars兼容Mustache,你可以在Handlebars中导入Mustache模板。

使用模板引擎

在app.js中通过以下两行代码设置了模板文件的存储位置和使用的模板引擎:

// view engine setup 
app.set('views', path.join(__dirname, 'views')); 
app.set('view engine', 'ejs'); 

注意:我们通过  express -e blog 只是初始化了一个使用 ejs 模板引擎的工程而已,比如 node_modules 下添加了 ejs 模块,views 文件夹下有 index.ejs 。并不是说强制该工程只能使用 ejs 不能使用其他的模板引擎比如 jade,真正指定使用哪个模板引擎的是  app.set('view engine', 'ejs'); 。

在 routes/index.js 中通过调用 res.render() 渲染模版,并将其产生的页面直接返回给客户端。它接受两个参数,第一个是模板的名称,即 views 目录下的模板文件名,扩展名 .ejs 可选。第二个参数是传递给模板的数据对象,用于模板翻译。

打开 views/index.ejs ,内容如下:

index.ejs

<!DOCTYPE html> 
<html> 
 <head> 
  <title><%= title %></title> 
  <link rel='stylesheet' href='/stylesheets/style.css' /> 
 </head> 
 <body> 
  <h1><%= title %></h1> 
  <p>Welcome to <%= title %></p> 
 </body> 
</html> 

当我们 res.render('index', { title: 'Express' }); 时,模板引擎会把 <%= title %> 替换成 Express,然后把替换后的页面显示给用户。

渲染后生成的页面代码为:

<!DOCTYPE html> 
<html> 
 <head> 
  <title>Express</title> 
  <link rel='stylesheet' href='/stylesheets/style.css' /> 
 </head> 
 <body> 
  <h1>Express</h1> 
  <p>Welcome to Express</p> 
 </body> 
</html> 

注意:我们通过  app.use(express.static(path.join(__dirname, 'public'))) 设置了静态文件目录为 public 文件夹,所以上面代码中的  href='/stylesheets/style.css' 就相当于 href='public/stylesheets/style.css' 。

ejs 的标签系统非常简单,它只有以下三种标签:

  • <% code %>:  JavaScript 代码。
  • <%= code %>:显示替换过 HTML 特殊字符的内容。
  • <%- code %>: 显示原始 HTML 内容。

注意:

<%= code %> 和  <%- code %> 的区别,当变量 code 为普通字符串时,两者没有区别。当 code 比如为  <h1>hello</h1> 这种字符串时, <%= code %> 会原样输出  <h1>hello</h1> ,而  <%- code %> 则会显示 H1 大的 hello 字符串。

一个简单的例子

通过命令新建一个ejs的项目: express -e demo

在index.js里添加如下代码:

var express = require('express'); 
var router = express.Router(); 
 
 
var items=[{title:'文章1'},{title:'文章2'}]; 
 
/* GET home page. */ 
router.get('/', function(req, res, next) { 
 res.render('index',{title:'文章列表',items:items}); 
}); 
 
router.get('/form', function(req, res, next) { 
  res.render('form',{title:'文章列表',message:'fendo8888'}); 
}); 
 
router.post('/form', function(req, res, next) { 
 res.redirect('/'); 
}); 
 
 
module.exports = router; 

在views下新建form.ejs添加如下代码:

<!DOCTYPE html> 
<html> 
 <head> 
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
  <title><%= title %></title> 
  <link rel='stylesheet' href='/stylesheets/style.css' /> 
 </head> 
 <body> 
  <form method="post" action="/form"> 
    <label>new article</label><br> 
    <textarea name="text" cols="100" row="5"></textarea> 
    <input type="submit" value="pus"></input> 
  </form> 
  <div><%=message%></div> 
 </body> 
</html> 

在index.ejs里添加如下代码:

<!DOCTYPE html> 
<html> 
 <head> 
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
  <title>文章列表页</title> 
  <link rel='stylesheet' href='/stylesheets/style.css' /> 
 </head> 
 <body> 
  <h1><%= title %></h1> 
  <p><a href="/form" rel="external nofollow" >发表新文章</a></p> 
  <ul> 
    <%items.forEach(function(item){%> 
     <li><%=item.title%></li> 
     <%})%> 
  </ul> 
 </body> 
</html> 

运行项目: npm start

访问:http://localhost:3000/

点击发表新文章

点击plus提交时,又回到首页

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# express  # ejs模版引擎  # ejs模板引擎  # node  # ejs  # 模板引擎  # node+express+ejs制作简单页面上手指南  # Node.js的路由、EJS模板引擎、GET和POST请求讲解  # 基于JavaScript写一款EJS模板引擎  # koa2使用ejs和nunjucks作为模板引擎的使用  # 详解在express站点中使用ejs模板引擎  # Node.js的Web模板引擎ejs的入门使用教程  # node.js 使用ejs模板引擎时后缀换成.html  # Express 框架中使用 EJS 模板引擎并结合 sill  # 客户端  # 文章列表  # 结合起来  # 发表新  # 的是  # 是一个  # 加载  # 你可以  # 都在  # 第一个  # 是由  # 其他的  # 不是很  # 第二个  # 扩展名  # 三种  # 是说  # 如果说  # 因为它  # 可选 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel与Inertia.js怎么结合_使用Laravel和Inertia构建现代单页应用  Python自动化办公教程_ExcelWordPDF批量处理案例  教你用AI将一段旋律扩展成一首完整的曲子  微信小程序 canvas开发实例及注意事项  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  高防服务器租用指南:配置选择与快速部署攻略  昵图网官网入口 昵图网素材平台官方入口  Laravel中的Facade(门面)到底是什么原理  Laravel如何自定义错误页面(404, 500)?(代码示例)  Laravel API资源类怎么用_Laravel API Resource数据转换  宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程  如何在万网自助建站中设置域名及备案?  Swift开发中switch语句值绑定模式  laravel怎么为API路由添加签名中间件保护_laravel API路由签名中间件保护方法  浅谈Javascript中的Label语句  如何实现javascript表单验证_正则表达式有哪些实用技巧  再谈Python中的字符串与字符编码(推荐)  如何基于云服务器快速搭建个人网站?  Win11怎么开启自动HDR画质_Windows11显示设置HDR选项  Laravel如何配置中间件Middleware_Laravel自定义中间件拦截请求与权限校验【步骤】  Laravel Facade的原理是什么_深入理解Laravel门面及其工作机制  如何快速上传建站程序避免常见错误?  桂林网站制作公司有哪些,桂林马拉松怎么报名?  个人网站制作流程图片大全,个人网站如何注销?  如何用AWS免费套餐快速搭建高效网站?  Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】  如何在万网自助建站平台快速创建网站?  Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程  香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南  iOS正则表达式验证手机号、邮箱、身份证号等  活动邀请函制作网站有哪些,活动邀请函文案?  EditPlus中的正则表达式实战(6)  C语言设计一个闪闪的圣诞树  香港服务器建站指南:外贸独立站搭建与跨境电商配置流程  千问怎样用提示词获取健康建议_千问健康类提示词注意事项【指南】  如何实现建站之星域名转发设置?  Laravel怎么发送邮件_Laravel Mail类SMTP配置教程  如何快速搭建二级域名独立网站?  Laravel Livewire是什么_使用Laravel Livewire构建动态前端界面  JS中页面与页面之间超链接跳转中文乱码问题的解决办法  Laravel如何使用模型观察者?(Observer代码示例)  Laravel Eloquent性能优化技巧_Laravel N+1查询问题解决  Laravel的HTTP客户端怎么用_Laravel HTTP Client发起API请求教程  Laravel怎么实现搜索高亮功能_Laravel结合Scout与Algolia全文检索【实战】  如何在IIS服务器上快速部署高效网站?  HTML5段落标签p和br怎么选_文本排版常用标签对比【解答】  Laravel如何生成API文档?(Swagger/OpenAPI教程)  Laravel如何实现文件上传和存储?(本地与S3配置)  如何用ChatGPT准备面试 模拟面试问答与职场话术练习教程  新三国志曹操传主线渭水交兵攻略