博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
jade模板引擎学习笔记(WebsStorm9.0.3+ nodejs+express+jade)
阅读量:6258 次
发布时间:2019-06-22

本文共 8987 字,大约阅读时间需要 29 分钟。

  •  
  •  
  • j

jade环境搭建

      打开WebsStorm9.0.3,File—New Project…,project type选择Node.js Express App,新建项目jadeTest,打开Terminal,输入npm install 安装程序需要的依赖项,安装成功后,环境就搭好了,打开app.js文件,找到jade模板引擎的引用代码如下

1 var express = require('express');2 var app = express();3 app.set('views', path.join(__dirname, 'views'));4 app.set('view engine', 'jade');

 

接下来,我们开始学习jade语法,程序的默认页面是index.jade,打开index.jade,然后在Terminal中输入以下命令:

jade -P -w index.jade

命令行:jade -P -w index.jade 实时监控jade文件,自动编译为不压缩的html文件,方便实时查看写的jade代码和html的比较

jade标签写法

index.jade

1 doctype html2 html3     head4         title jade标签写法5     body6         P 文档声明:doctype html7         P 标签省去尖括号,元素和文本用空格间隔8         div9             P 元素的父子关系用空格缩进表示

编译成html:

1  2  3    4     jade学习 5    6    7     

文档声明:doctype html

8

标签省去尖括号,元素和文本用空格间隔

9
10

元素的父子关系用空格缩进表示

11
12 13

 jade注释 

  单行注释: //

  编译成html:<!-- 单行注释 -->  

1 doctype html2 html3     head4         title jade学习5     body6          p 单行注释://7         //div8              p 测试单行注释

编译成html

1  2  3    4     jade学习 5    6       7     

单行注释://

8
10 11

 块注释://

1 doctype html2 html3     head4         title jade学习5     body       6         p 块注释://7         //8             div9                p 测试块注释

编译成html

1  2  3    4     jade学习 5    6    7     7     

块注释://

8
12 13

非缓存注释:注释的内容不会显示在编译的html中

1 doctype html2 html3     head4         title jade学习5     body6         P 非缓存注释/块注释://-7         //-div8             p 测试多行注释9

编译成html

1 2 3   4     jade学习5   6       7     

非缓存注释/块注释://-

8 9

 

jade添加类名、id、属性  

 

1 doctype html 2 html 3     head 4         title jade学习 5     body 6        div.className#idName 7            p.className 类名加点紧跟元素后面或者id后面,不用加空格,后面紧跟的文本属性要加空格 8            p#idTest id名加#紧跟元素后面或者类后面,不用加空格,后面紧跟的文本要加空格 9        #testDiv div如果有className/id,可以省略元素div10        .classDiv div如果有className/id,可以省略元素div11        h1 属性添加12        .className13            p 属性放在小括号里,紧跟元素/id/ClassName后面,属性之间用逗号隔开,id或class也可以放在括号内14            input.classP(id='content',type='text',value="添加属性")

编译成html

1  2  3    4     jade学习 5    6    7     
8

类名加点紧跟元素后面或者id后面,不用加空格,后面紧跟的文本属性要加空格

9

id名加#紧跟元素后面或者类后面,不用加空格,后面紧跟的文本要加空格

10
11
div如果有className/id,可以省略元素div
12
div如果有className/id,可以省略元素div
13

属性添加

14
15

属性放在小括号里,紧跟元素/id/ClassName后面,属性之间用逗号隔开,id或class也可以放在括号内

16
17
18 19

 

Jade添加脚本,css 

1 doctype html 2 html 3     head 4         meta 5         title #{title} 6         style. 7             .className{ 8                 background: red; 9                 width:200px;10             }11             #id1{12                 background: blue;13                 width: 200px;14             }15         script.16             var s='test';17     body

编译成html

1  2  3    4     
5 6 16 17 18 19 20

 

jade变量

 服务器端代码:以 '-'开头的代码

 变量的引用方式:

    #{表达式}    

    = 表达式

    !{表达式}

    != 表达式

1 doctype html 2 html 3     head 4         title jade学习 5     body 6         -var test="以'-'开头写服务器端代码" 7         p #{test} 8         -var str='test1' ; 9         -var strTest='

变量调用

';10 p #{str.toUpperCase()}11 p= str12 //转义引用,(#{表达式} 等价于 =表达式)13 p #{strTest}14 p= strTest15 //非转义引用,(!{表达式}等价于 !=表达式)16 p !{strTest}17 p!= strTest

 编译成html

1  2  3    4     jade学习 5    6    7     

以'-'开头写服务器端代码

8

TEST1

9

test1

10
11

<div><p>变量调用</p></div>

12

<div><p>变量调用</p></div>

13
14

变量调用

15

变量调用

16 17
直接显示#{title}表达式引用方法: p \#{title} p \!{title} 编译成html 

#{title}

!{title}

 

注意:

input(value=data),data有值就显示值,没有值就什么也不显示
input(value=#{data})data有值就显示值,没有值显示undifined
模板里的数据优先级高于外部传进来的数据 可以传递json数据 可以对表达式进行进行操作,例如:
 1 -var c='test1' ; 2 p #{c.toUpperCase()} 
编译成html为:

TEST1

jade多行文本显示 

多行文本显示有2中方式

1.标签后边紧跟点 

1
2
3
4
5
6
7
p#id2.className.
       
22222
       
<
strong
>6666</
strong
>
       
3333
       
<
span
>888</
span
>
       
4444
       
555

 2.标签后面的文本以|开头 

p#id3       |222       strong 888       |3333       span 9999       |444

  

jade流程代码:for,each,while

for 遍历数组的for
-var arry=[1,3,5,7,9];     ul        -for (var i=0;i

编译成html

  • 1
  • 3
  • 5
  • 7
  • 9
遍历对象属性的for
-var json={name:'tom',age:9,phone:13222222222};      -for(var j in json)       p= json[j]

编译成html

tom

9

13222222222

each 遍历数组
-var arry=[1,3,5,7,9];     -each value,index in arry       p #{index}:#{value}
each item in arry p= item
 

  编译成html

0:1

1:3

2:5

3:7

4:9

1

3

5

7

9

 
遍历json数据
-var json={name:'tom',age:9,phone:13222222222};     ul      -each value,key in json       li #{key}:#{value}
编译成html
  • name:tom
  • age:9
  • phone:13222222222
while 
1
2
3
4
-var j=0;
    
ul
        
while j<3
           
li= j++

  编译成html

1
2
3
4
<
ul
>
      
<
li
>0</
li
>
      
<
li
>1</
li
>
      
<
li
>2</
li
><
br
> </
ul
>

 jade流程代码:if - else - unless ,case

   if - else - unless  

 
-var arry=['hello','world','good','test'] if arry if(arry.length>2) div p= arry[0] +':if' p= arry[1]+':if' else p 数组长度等于小于2 else p 数组为空 unless arry.length<=2 div p= arry[0] p= arry[1]

编译成html

hello:if

world:if

hello

world

注: unless 相当于非,unless false 才执行代码

 case

case相当于switch

 

-var arry=['hello','world','good','test']
  
each item in arry
         
case item
            
when 'hello'
            
when 'world'
              
p hello Tom!
            
when 'good': P Good News
            
default
               
P #{item}

 

  编译成html

hello Tom!

hello Tom!

Good News

test

<
span 
style="font-size: 16px; background-color: #ffff00;">注意:</
span
><
br
>when 'world'
   
p hello Tom!<
br
>或者
when 'good': P Good News <
br
>效果是一样的

 可重用的jade块Mixins

 1.Mixins简单说就是代码块复用

//定义代码块      mixin bags        div.allBags           p 书包           p 文具包           p 公文包           p 工具包      //调用      +bags

编译成html

1
2
3
4
5
6
7
8
<!--定义代码块-->
<!--调用-->
    
<
div 
class="allBags">
      
<
p
>书包</
p
>
      
<
p
>文具包</
p
>
      
<
p
>公文包</
p
>
      
<
p
>工具包</
p
>
    
</
div
>

  2.可以为mixin定义参数   

//参数个数确定
mixin parameters(name,age)
  
p #{name}今年#{age}岁
+parameters('小明',6)
+parameters('小强',8)
 
//参数个数不确定
mixin parameterList(name,...items)
  
h1= name
  
ul
    
each nn in items
     
li= nn
+parameterList('小明','早晨读书','中午练书法','下午练拳')

 

  编译成html

<!--参数个数确定-->
        
<
p
>小明今年6岁</
p
>
        
<
p
>小强今年8岁</
p
>
    
<!--参数个数不确定-->
        
<
h1
>小明</
h1
>
        
<
ul
>
          
<
li
>早晨读书</
li
>
          
<
li
>中午练书法</
li
>
          
<
li
>下午练拳</
li
>
        
</
ul
>

 3.mixin可以嵌套使用 

mixin bags        div.allBags           p 书包           p 文具包           p 公文包           p 工具包      //调用           mixin getBags(name)        P(class= name) 请列举包的种类        +bags      +getBags('back')

编译成html

请列举包的种类

书包

文具包

公文包

工具包

4.mixin可以从外部传入代码块

mixin bags        div.allBags           p 书包           p 文具包           p 公文包           p 工具包           //block:外部传入的代码块关键字           if block              block +bags        h1 外部代码块        div            p 外部代码块1            p 外部代码块2

编译成html

书包

文具包

公文包

工具包

外部代码块

外部代码块1

外部代码块2

5.mixin支持传递属性

mixin GetAttrs(name1,name2)         h1 传递属性的方法1         p(class!=attributes.class)= name1         h1 传递属性的方法2         p&attributes(attributes)= name2      +GetAttrs('方法1','方法2')(class='redColor',id='passId')

编译成html

传递属性的方法1

方法1

传递属性的方法2

方法2

 模板继承(extends)

继承者里如果与模板里有同名的block,继承者里同名的block会覆盖掉模板里的block

layout.jade

doctype htmlhtml  head    title= title    link(rel='stylesheet', href='/stylesheets/style.css')  body

index7.jade

//layout.jdae与index7.jade是同一个目录下 extends layoutblock content    p 继承模板layout

index7.jade编译成html

1
2
3
4
5
6
7
8
9
10
<!
DOCTYPE 
html>
<
html
>
  
<
head
>
    
<
title
></
title
>
    
<
link 
rel="stylesheet" href="/stylesheets/style.css">
  
</
head
>
  
<
body
>
    
<
p
>继承模板layout</
p
>
  
</
body
>
</
html
>

 

模板包含(include)

把很多块引用到一个页面中

index8.jade

doctype htmlhtml    head       include ../templates/head    body        p 引入静态的jade css        include ../templates/css        p 引入html文件        include  ../templates/content.html        P 引入页脚模块        include ../templates/footer

编译成html

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<!
DOCTYPE 
html>
<
html
>
  
<
head
>
    
<
title
></
title
>
    
<
link 
rel="stylesheet" href="/stylesheets/style.css">
  
</
head
>
  
<
body
>
    
<
p
>引入静态的jade css</
p
>
    
<
style
>
      
p{
      
background:blue;
      
}
    
</
style
>
    
<
p
>引入html文件</
p
><
div
>引用html</
div
>
    
<
P
>引入页脚模块</
P
>
    
<
div
>页脚模块</
div
>
  
</
body
>
</
html
>

  

下面这些文件的位置是在index8.jade上一级目录templates中

head.jade

title= titlelink(rel='stylesheet', href='/stylesheets/style.css')

css.jade

style.    p{    background:blue;    }

content.html

引用html

footer.jade

div 页脚模块

 

作者: 

出处: 
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

转载:http://www.cnblogs.com/greenteaone/p/4636452.html

你可能感兴趣的文章
Jackson使用ObjectManage#readValue传入泛型T的问题
查看>>
Python正则表达式中的re.S的作用
查看>>
从零开始构建一个centos+jdk7+tomcat7的docker镜像文件
查看>>
Source Insight 中文注释为乱码解决办法(完美解决,一键搞定)
查看>>
【LoadRunner】安装LoadRunner
查看>>
Linux内存管理 (15)页面迁移
查看>>
在高并发、高负载的情况下,如何给表添加字段并设置DEFAULT值?
查看>>
Cocos2d-x 3.0final 终结者系列教程13-贪食蛇游戏案例(全)
查看>>
Nginx的try_files指令和命名location使用实例
查看>>
IO多路复用之select
查看>>
pd_ds中的hash
查看>>
买书不读是一种什么病?
查看>>
微信接口开发报错invalid credential, access_token is invalid or not latest hint
查看>>
nohup 部署springboot 使用命令
查看>>
MQ产品比较-ActiveMQ-RocketMQ
查看>>
暂时没有想好呢。
查看>>
windows服务 MVC之@Html.Raw()用法 文件流的读写 简单工厂和工厂模式对比
查看>>
PHP解析URL并得到URL中的参数
查看>>
【vue.js】绑定click事件
查看>>
字体属性
查看>>