标签:转义 特点 style xxx pre 页面 简单 返回 styles
通常根据后端返回的json数据,然后来生成html被称为前端渲染,而后端渲染是后端把json和html结合渲染好后再返回浏览器,没前端什么事了
无论前后谁渲染页面,都会用到模板引擎,前端操作页面实际上是操作dom,后端渲染页面是把数据和html字符拼接后丢给浏览器
引擎 | 前端 | 后端 |
---|---|---|
angularJs | √ | × |
vue/mustach | √ | √ |
react | √ | √ |
angularTs/mustach | √ | √ |
jade/pug | × | √ |
ejs | × | √ |
jquery + art-template | √ | × |
handlerbars | √ | × |
原理: fs抓取前端静态页面 + ejs + 数据 -> 返回send(data) -> 浏览器
特点:非侵入式,温和,依赖弱
ejs模板文件语法
const ejs = require("ejs");
app.get("/", (req, res) => {
ejs.renderFile("./views/index.ejs", data, (err, data) => {
if (!err) {
res.send(data);
}
});
});
let data = {
title: "ejs模板标题",
list: [
{ id: 1, name: "cc", age: 10 },
{ id: 2, name: "cc", age: 10 },
{ id: 3, name: "cc", age: 10 }
],
html: "<strong>强壮的</strong>"
};
<title><%=title%></title>
<ul>
<% for(let i=0,len=list.length;i<len;i++){
%><li><a href="#"><%=list[i].id+list[i].name%></a></li><%
}
%>
</ul>
<%-html%>
<%-include("./hd.ejs",{title:'啦啦啦'})%>
得先部署静态资源
app.use(express.static("./public"));
再ejs文件引入外部样式,注意url地址是相对 静态资源地址根目录 的路径
<link rel="stylesheet" href="/css/style.css">
该方式的 ejs文件 默认放在==views==目录下
res.render("./index.ejs", data);
可以手动更改默认的模板文件夹
app.set("views", "pages");//将默认文件夹改为pages
//中间件配置
app.set('view.engine','html'); //模板最终 输出类型设置
app.set('views','./views'); //引擎模板目录设置
app.engine('html',consolidate.ejs); //输出与引擎匹配
app.engine('css',consolidate.jade); //输出与引擎匹配
//渲染
app.get('xxx',(req,res)=>{
res.render('模板文件名',{数据}) //整合页面和数据,完成渲染,发往浏览器,并结束响应
})
以上就是本人对于ejs的简单了解,如有不对,欢迎指出~
标签:转义 特点 style xxx pre 页面 简单 返回 styles
原文地址:https://www.cnblogs.com/Cc-qm/p/12489927.html