什么是模板引擎

模板引擎(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 %> 和 <%- 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
# 客户端
# 文章列表
# 结合起来
# 发表新
# 的是
# 是一个
# 加载
# 你可以
# 都在
# 第一个
# 是由
# 其他的
# 不是很
# 第二个
# 扩展名
# 三种
# 是说
# 如果说
# 因为它
# 可选
相关文章:
如何做静态网页,sublimetext3.0制作静态网页?
在线制作视频的网站有哪些,电脑如何制作视频短片?
东莞专业网站制作公司有哪些,东莞招聘网站哪个好?
网站制作壁纸教程视频,电脑壁纸网站?
做企业网站制作流程,企业网站制作基本流程有哪些?
香港服务器租用每月最低只需15元?
如何零基础开发自助建站系统?完整教程解析
怀化网站制作公司,怀化新生儿上户网上办理流程?
css网站制作参考文献有哪些,易聊怎么注册?
网站建设设计制作营销公司南阳,如何策划设计和建设网站?
如何通过免费商城建站系统源码自定义网站主题与功能?
网站制作和推广的区别,想自己建立一个网站做推广,有什么快捷方法马上做好一个网站?
哈尔滨网站建设策划,哈尔滨电工证查询网站?
三星网站视频制作教程下载,三星w23网页如何全屏?
电视网站制作tvbox接口,云海电视怎样自定义添加电视源?
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?
微信推文制作网站有哪些,怎么做微信推文,急?
如何在Windows服务器上快速搭建网站?
建站之星×万网:智能建站系统+自助建站平台一键生成
C++时间戳转换成日期时间的步骤和示例代码
建站之星价格显示格式升级,你的预算足够吗?
已有域名和空间如何快速搭建网站?
如何快速生成高效建站系统源代码?
定制建站如何定义?其核心优势是什么?
建站主机CVM配置优化、SEO策略与性能提升指南
如何选择建站程序?包含哪些必备功能与类型?
北京网站制作网页,网站升级改版需要多久?
PHP正则匹配日期和时间(时间戳转换)的实例代码
b2c电商网站制作流程,b2c水平综合的电商平台?
如何登录建站主机?访问步骤全解析
建站主机如何选?性能与价格怎样平衡?
南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?
利用JavaScript实现拖拽改变元素大小
定制建站价位费用解析与套餐推荐全攻略
成都响应式网站开发,dw怎么把手机适应页面变成网页?
太原网站制作公司有哪些,网约车营运证查询官网?
非常酷的网站设计制作软件,酷培ai教育官方网站?
一键制作网站软件下载安装,一键自动采集网页文档制作步骤?
头像制作网站在线制作软件,dw网页背景图像怎么设置?
大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?
如何撰写建站申请书?关键要点有哪些?
建站主机如何选?高性价比方案全解析
专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?
如何在Golang中引入测试模块_Golang测试包导入与使用实践
高防服务器租用指南:配置选择与快速部署攻略
宝塔新建站点为何无法访问?如何排查?
建站之星如何助力网站排名飙升?揭秘高效技巧
网站制作网站,深圳做网站哪家比较好?
如何选择高性价比服务器搭建个人网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。