Jade语法

一、代码

不会被缓冲代码

ul
- for(var i=0; i<; i++)
li Jade Engine

会转换为:

<ul>
<li>Jade Engine</li>
<li>Jade Engine</li>
<li>Jade Engine</li>
</ul>

被缓冲代码

  p= 'Hello Jade'

会转换为:

<p>Hello Jade</p>

注意: =默认会转义内容

p= 'Welcome to wandoujia fe, we want <b>you</b>'

会转换为:

<p>Welcome to wandoujia fe, we want &lt;b&gt;you&lt;/b&gt;</p>

如果不想被转义的,在=前面添加!

p!= 'Welcome to wandoujia fe, we want <b>you</b>'

会转换为:

<p>Welcome to wandoujia fe, we want <b>you</b></p>

二、使用变量

- var name = 'Jade'
p my name is #{name}

会转换为:

<p>my name is Jade</p>

如果要输出 #{},那就得使用/来转义

- var name = 'yaochun'
p my name is \#{name}

会转换为:

<p>my name is #{name}</p>

变量中的特殊字符会被转义,如:

- var name = '<script></script>'
| #{name}

会转换为:

&lt;script&gt;&lt;/script&gt;

如要得到不转义的,用!替换#来调用

- var name = '<script></script>'
| !{name}

会转换为:

<script></script>

| 其实就是管道,一般也可以定义一段文本

三、循环

语法结构:

each VAL[,KEY] in OBJ
  • VAL是值
  • KEY是键,可选
  • OBJ是对象,array or object

数组实例

- var jobs = ["fe", "wandoujia", "beijing", "We want you"]
each job in jobs
li= job

会转换为:

<li>fe</li>
<li>wandoujia</li>
<li>beijing</li>
<li>We want you</li>

对象实例

- var jobs = {"catagory" : "fe", "company" : "wandoujia", "local" : "beijing"}
each val,key in jobs
li #{key} : #{val}

会转换为:

<li>catagory : fe</li>
<li>company : wandoujia</li>
<li>local : beijing</li>

四、Case

case主要的作用和js里面的switch一样

方式一 本文推荐的方式

- var apples = 1
case apples
when 0
p you have no apples
when 1
p you have an apple
default
p you have #{apples} apples

会转换为:

<p>you have an apple</p>

方式二

- var apples = 1
case apples
when 0: p you have no apples
when 1: p you have an apple
default: p you have #{apples} apples

方式三

有些时候,确实有需求合并一些when的情况

- var apples = 1
case apples
when 0
when 1
p you have few apples
default
p you have #{apples} apples

当apples这个值为0或者1的时候会转换为:

<p>you have few apples</p>

五、过滤器

支持markdown

注意:必须是已经安装 markdown-js 或者 node-discount

:markdown
我们来自豌豆荚前端,欢迎有志之士加盟,简历发送至zhangyaochun@wandoujia.com

会转换为:

<p>我们来自豌豆荚前端,欢迎有志之士加盟,简历发送至zhangyaochun@wandoujia.com</p>

六、Mixins

无参数的mixin

mixin join
ul
li 我们需要一帮人
li 喜欢前端
li 了解前端
li 愿意在前端不断学习奋斗的
li 你是吗?
li 快来加入我们把 +join()

会转换为:

<ul>
<li>我们需要一帮人</li>
<li>喜欢前端</li>
<li>了解前端</li>
<li>愿意在前端不断学习奋斗的</li>
<li>你是吗?</li>
<li>快来加入我们把</li>
</ul>

有参数的mixin

mixin join(company)
ul
li 我们 #{company} 需要一帮人
li 喜欢前端
li 了解前端
li 愿意在前端不断学习奋斗的
li 你是吗?
li 快来加入我们 #{company} 把 +join('wandoujia')

会转换为:

<ul>
<li>我们 wandoujia 需要一帮人</li>
<li>喜欢前端</li>
<li>了解前端</li>
<li>愿意在前端不断学习奋斗的</li>
<li>你是吗?</li>
<li>快来加入我们 wandoujia 把</li>
</ul>

minxin中支持block

mixin join(company)
ul
li 我们需要一帮人
li 喜欢前端
li 了解前端
li 愿意在前端不断学习奋斗的
if block
block
else
li 你是吗?
li 快来加入我们把 +join('wandoujia')
li 我们这有神马?
li 我们这个有一帮能折腾的老师阿姨
li 我们这有美丽的阿姨
li 我们每周都有技术交流
li 我们这可以用很多开源的新技术

会转换为:

<ul>
<li>我们需要一帮人</li>
<li>喜欢前端</li>
<li>了解前端</li>
<li>愿意在前端不断学习奋斗的</li>
<li>我们这有神马?</li>
<li>我们这个有一帮能折腾的老师阿姨</li>
<li>我们这有美丽的阿姨</li>
<li>我们每周都有技术交流</li>
<li>我们这可以用很多开源的新技术</li>
</ul>

minxin中还支持attributes

mixin link(href, name)
a(class!=attributes.class, title!=attributes.title, href=href)= name +link('http://wandoujia.com/join', '豌豆荚前端招聘')(class="btn", title="招聘啦,小伙伴快来点")

会转换为:

<a title="招聘啦,小伙伴快来点" href="http://wandoujia.com/join" class="btn">豌豆荚前端招聘</a>

七、包含

有点类似freemaker,通过include来载入一些jade模板

转自:http://www.w3cplus.com/html/jade.html

Jade模板引擎学习(二)语法:代码、变量、循环、过滤器及mixin的更多相关文章

  1. jade模板引擎学习笔记(WebsStorm9.0.3+ nodejs+express+jade)

    jade环境搭建 jade标签写法 jade注释 jade添加类名.id.属性 jade添加脚本,css jade变量 jade多行文本显示 jade流程代码:for,each,while jade流 ...

  2. Jade模板引擎学习(一)安装及基本语法

    Jade是一款高性能简洁易懂的模板引擎,Jade是Html的Javascript实现,在服务端(NodeJS)及客户端均有支持. 一.功能 客户端支持  超强的可读性 灵活易用的缩进 块扩展 代码默认 ...

  3. Express全系列教程之(十):jade模板引擎

    一.前言 随着前端业务的不断发展,页面交互逻辑的不断提高,让数据和界面实现分离渐渐被提了出来.JavaScript的MVC思想也流行了起来,在这种背景下,基于node.js的模板引擎也随之出现. 什么 ...

  4. Jade 模板引擎使用

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

  5. artTemplate模板引擎学习实战

    在我的一篇关于智能搜索框异步加载数据的文章中,有博友给我留言,认为我手写字符串拼接效率过低,容易出错.在经过一段时间的摸索和学习之后,发现现在拼接字符串的方法都不在是自己去书写了,而是使用Javasc ...

  6. Express框架之Jade模板引擎使用

    日期:2018-7-8  十月梦想  node.js  浏览:2952次  评论:0条 前段时间讲说了ejs模板引擎,提到了jade的效率等等问题!今天在这里简单提一下jade的使用方式!结合expr ...

  7. Jade模板引擎使用详解

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

  8. nodejs jade 模板 引擎的使用方法

    1.新建项目 2.使用模板引擎 app.set('view engine','jade'); 3.使用render渲染一个视图 res.render(用于指定需要被渲染的视图(必选),本地变量(可选) ...

  9. NVelocity模板引擎学习笔记

    NVelocity模板引擎学习笔记 学习模板引擎有一段时间现在做一些总结

随机推荐

  1. C#程序 权限不够的解决方案

    有时候需要操作硬件,或者启动windows服务程序时,系统会提示很多奇怪的问题,归根结底就是程序当前所拥有的权限不够,需要提升,以前我们时手写一个manifest,多不容易啊, 现在有正常的方法了 1 ...

  2. PSP1123

    PSP时间图: 类型 任务 开始时间 结束时间 净时间 中断时间 日期 开会 开会 16:17 16:50 33 0 20171027 开会 开会 17:00 17:22 22 0 20171028 ...

  3. 第十九次ScrumMeeting会议

    第十九次Scrum Meeting 时间:2017/12/9 地点:三公寓大厅 人员:蔡帜 王子铭 游心 解小锐 王辰昱 李金奇 杨森 陈鑫 赵晓宇 照片: 目前工作进展 名字 今日 明天的工作 蔡帜 ...

  4. <Effective C++>读书摘要--Designs and Declarations<一>

    <Item 18> Make interfaces easy to use correctly and hard to use incorrectly 1.That being the c ...

  5. Kafka Streams演示程序

    本文从以下六个方面详细介绍Kafka Streams的演示程序: Step 1: 下载代码 Step 2: 启动kafka服务 Step 3: 准备输入topic并启动Kafka生产者 Step 4: ...

  6. URL中编码问题

    1.http协议传输统一iso-8859-1传输 jsp中用request.getparameter("keword");得到的是iso-8859-1翻译过来的,要用 keywor ...

  7. [C/C++] const用法详解

    const在C语言中算是一个比较新的描述符,我们称之为常量修饰符,意即其所修饰的对象为常量(immutable). 我们来分情况看语法上它该如何被使用. 1.函数体内修饰局部变量.例:void fun ...

  8. Java中的缓冲流详解

    缓冲流增强了读写文件的能力,比如Student.txt是一个学生的名单,每个姓名占一行.如果我们想要读取名字,那么每次必须读取一行,使用FileReader流很难完成这样的任务,因为我们不清楚一行有多 ...

  9. hdu 3015 Disharmony Trees (离散化+树状数组)

    Disharmony Trees Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  10. Trie字典树的学习及理解

    字典树详解见此 我这里学习时主要是看了李煜东的进阶指南里的讲解,以下是书中介绍的内容. Trie,又称字典树,是一种用于实现字符串快速检索的多叉树结构,Tire的每个节点都拥有若干个字符指针,若在插入 ...