jade/ejs 模板引擎

http://jade-lang.com/

http://www.nooong.com/docs/jade_chinese.htm

SSR 服务器端渲染 服务器生成html字符串

cnpm i jade ejs

html                    <html>
head <head>
style <style></style>
link <link></link>
script <script></link>
</head> body
div
ul
li </html>

jade:

var html = jade.reander(标签名);

var html = jade.reanderFile("xxx.jade",{pretty:true,data....});

pretty:美化

属性 内容

div(id="div1",class="box") 内容

div#div1.box 内容

div&attributes({id:'div1', class:'box'}) 内容

div(class=["box1","box2","box3"])

样式:

div(sytle="width:200px;....")

div(sytle={width:"200px",....})

多行 | 或 . 或 include 文件名
数据:#{name}
循环:
        -for(){
li
-}
1.jade
html
head
style #div1{width:200px;height:200px;background:red;}
link(rel="stylesheet",href="index.css")
script(src="a.js")
script
|window.onload = function(){
| alert(1);
|}
body
div(style="width:200px;height:200px;background:red;") 内容
div(style={width:"200px",height:"200px",background:"red"}) 内容
div aaaa
|bbbb
|cccc
div(class="box1 box2 box3") class
div(class=["box1","box2","bo3"]) class arr
div&attributes({id:'div1', class:'box'})
ul
li 我叫#{name},今年#{age}岁
ul
-for(var i = 0; i < data.length; i++){
li 我叫#{data[i].name},今年#{data[i].age}岁
-}

1.js

var jade = require("jade");
var str = jade.renderFile("3.jade",{pretty:true,
name:"如花",age:18,
data:[
{name:"如花",age:18},
{name:"翠花",age:28},
{name:"豆腐花",age:38}
] }); console.log(str);//html页面


ejs:

cnpm i ejs

http://www.ejs.co/ 英文

https://ejs.bootcss.com/ 中文

<% '脚本' 标签,用于流程控制,无输出。

<%= 输出数据到模板(输出是转义 HTML 标签) 原样输出

<%- 输出非转义的数据到模板 转义成标签

<%-/= include 文件名%>

<%-/= include("文件名",数据)%>

<%-/= include %>直接将文件内容引过来


js:
var ejs = require("ejs");

ejs.renderFile("52.ejs",{
name:"翠花",age:20,
data:[
{name:"如花",age:18},
{name:"翠花",age:28},
{name:"豆腐花",age:38}
]
},function(err,str){
console.log(err,str);
});
52.ejs:
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>无标题文档</title>
</head> <body>
<ul> <ul>
<%- include tmpli2.ejs%>
</ul> </ul>
</body>
</html>
tmpli2.ejs:
<%for(var i = 0; i < data.length; i++){%>
<li>我叫<%=data[i].name%>,今年<%=data[i].age%>岁</li>
<%}%>

res:

express集成模板引擎

app.set("view engine","ejs/jade"); 设置模板引擎

app.set("views","./views"); 模板文件存放的目录

使用:

res.render("index",data);

consolidate

npm i consolidate

app.set("view engine",html); 设置模板引擎

app.set("views","./views"); 模板文件存放的目录

app.engine("html",consolidate.ejs/jade/pug/....); 使用什么方法去解析你的模板文件

consolidate.ejs--->ejs.renderFile

consolidate.jade--->jade.renderFile

app1.js(ejs)

var express = require("express");
var ejs = require("ejs");
var app = express(); app.listen(9000); app.get("/index.html",function(req,res){ ejs.renderFile("index.ejs",{name:"aaa",age:18},function(err,data){
res.send(data);
});
});

app2.js(ejs)

var express = require("express");
var app = express(); app.listen(9000); //配置模板引擎
app.set("view engine","ejs");
app.set("views","./views"); app.get("/index.html",function(req,res){
res.render("index.ejs",{name:"aaa",age:18});
});

app3.js(jade)

var express = require("express");
var app = express(); app.listen(9000); //配置模板引擎
app.set("view engine","jade");
app.set("views","./views"); app.get("/index.html",function(req,res){
res.render("index.jade",{name:"aaa",age:18});
});

app4.js(html)

var express = require("express");
var ejs = require("ejs");
var app = express(); app.listen(9000); //配置模板引擎
app.set("view engine","html");
app.set("views","./views");
app.engine("html",ejs.renderFile); app.get("/index.html",function(req,res){
res.render("index",{name:"aaa",age:18});
});

app5.js(html)

var express = require("express");
var consolidate = require("consolidate");
var app = express(); app.listen(9000); //配置模板引擎
app.set("view engine","html");
app.set("views","./views");
app.engine("html",consolidate.ejs); app.get("/index.html",function(req,res){
res.render("index",{name:"aaa",age:18});
});

7、 jade 、 ejs、express集成模板的更多相关文章

  1. Express下ejs的视图模板引擎的建立

    写在前面 由于Express升级到4.0,将ejs的用法忽略,改为用户自定义形式,所以要引入库index.js作为引擎,来支持ejs的模板引擎(点击下载). 首先是建立一个名字叫nodeitem,引擎 ...

  2. Express:模板引擎深入研究

    深入源码 首先,看下express模板默认配置. view:模板引擎模块,对应 require('./view'),结合 res.render(name) 更好了解些.下面会看下 view 模块. v ...

  3. express jade ejs 为什么要用这些?

    express是快速构建web应用的一个框架   线上文档 http://www.expressjs.com.cn/ 不用express行不行呢?    看了网上的回答:不用express直接搭,等你 ...

  4. 模板引挚 jade ejs

    // asl sum翡翠 后台使用如下: const jade = require('jade') //pretty 美化的意思,指的是渲染的布局会美化   2020-2-15 var str = j ...

  5. node jade || ejs引擎模板

    1.jade:破坏式2.ejs:保留式 -------------------------------------------------------------------------------- ...

  6. express 默认模板引擎

    使用express -t ejs microblog创建出来的居然不是ejs项目,而是jade项目.现在的版本已经没有-t这个命令了,改为express -e microblog.运行完之后,根据提示 ...

  7. nodejs express template (模版)的使用 (ejs + express)

    var app=require("express").createServer(); app.set("view engine","ejs" ...

  8. express html模板项目搭建

    初学express的亲们,估计要弄ejs和jade会比较烦躁,那就先html开始,简单笔记如下:   1.新建项目文件夹demotest 2.进入demotest    >express -e ...

  9. Jade(Pug) 模板引擎使用文档

    本篇内容 在 Express 中调用 jade 模板引擎 jade 变量调用 if 判断 循环 Case 选择 在模板中调用其他语言 可重用的 jade 块 (Mixins) 模板包含 (Includ ...

随机推荐

  1. CSS魔法堂:那个被我们忽略的outline

    前言  在CSS魔法堂:改变单选框颜色就这么吹毛求疵!中我们要模拟原生单选框通过Tab键获得焦点的效果,这里涉及到一个常常被忽略的属性--outline,由于之前对其印象确实有些模糊,于是本文打算对其 ...

  2. ESP-EYE V2.1 开发板 WINDOWS 10 开发入门

    准备工作 1 × ESP-EYE V2.1 开发板 1 × Micro USB B 电缆 1 × PC(Windows10) 简介 ESP-EYE 是一款面向人脸识别和语音识别市场的开发板,搭载 ES ...

  3. JSONObject、JSONArray、Map、JavaBean的相互转换

    1,JSONObject json对象,就是一个键对应一个值,使用的是大括号{ },如:{key:value} 2,JSONArray json数组,使用中括号[ ],只不过数组里面的项也是json键 ...

  4. [C#] 将NLog输出到RichTextBox,并在运行时动态修改日志级别过滤

    作者: zyl910 一.缘由 NLog是一个很好用的日志类库.利用它,可以很方便的将日志输出到 调试器.文件 等目标,还支持输出到窗体界面中的RichTextBox等目标. 而且它还支持在运行时修改 ...

  5. 阿里云物联网平台体验(NetGadgeteer+C#篇)

    目前对接阿里云物联网平台有多种软件和硬件,可以有多种不同语言来实现对接,比如c/c++,Java,JS,Python,C#等等,不过C#版本只有PC对接云平台的代码,嵌入式的目前还没有看到,所以本篇文 ...

  6. git图解

  7. Docker Mysql数据库双主同步配置方法

    一.背景 可先查看第一篇<Docker Mysql数据库主从同步配置方法>介绍 二.具体操作 1.创建目录(~/test/mysql_test1): --mysql --mone --da ...

  8. 深入理解Linux内存分配

    深入理解Linux内存分配 为了写一个用户层程序,你也许会声明一个全局变量,这个全局变量可能是一个int类型也可能是一个数组,而声明之后你有可能会先初始化它,也有可能放在之后用到它的时候再初始化.除此 ...

  9. [AS3 3D Demo] Stage3D学习过程中开发的3个Demo

    1.飞机大战 基于Starling开发,使用了对象池技术的Demo. 2.3D人物2D背景游戏Demo 基于Away3D开发,实现了3D资源管理.寻路和跳跃等功能. 3.全3D游戏Demo 基于Awa ...

  10. json、数组、html标签的修改删除

    存数组 var aa=[1,2,3]; var sStorage=window.sessionStorage; sStorage.aa=aa; console.log(sStorage.aa); // ...