js代码嵌套html代码,实现js实现html代码嵌套doT.js插件

doT.js详细介绍

doT.js特点是快,小,无依赖其他插件。

使用方法:

{{= }} for interpolation

{{ }} for evaluation

{{~ }} for array iteration

{{? }} for conditionals

{{! }} for interpolation with encoding

{{# }} for compile-time evaluation/includes and partials

{{## #}} for compile-time defines

调用方式:

var tmpText = doT.template(模板);tmpText(数据源);

例子一:

1、for interpolation 赋值

格式:

{{= }}

数据源:{"name":"Jake","age":31}

区域:

模板:

Hi {{=it.name}}!
{{=it.age || ''}}

调用方式:

var dataInter = {"name":"Jake","age":31};

var interText = doT.template($("#interpolationtmpl").text());

$("#interpolation").html(interText(dataInter));

例子二:

2、for evaluation for in 循环

格式:

{{ for var key in data { }}

{{= key }}

{{ } }}

数据源:{"name":"Jake","age":31,"interests":["basketball","hockey","photography"],"contact":{"email":"jake@xyz.com","phone":"999999999"}}

区域:

模板:

{{ for(var prop in it) { }}

KEY:{{= prop }}---VALUE:{{= it[prop] }}

{{ } }}

调用方式:

var dataEval = {"name":"Jake","age":31,"interests":["basketball","hockey","photography"],"contact":{"email":"jake@xyz.com","phone":"999999999"}};

var evalText = doT.template($("#evaluationtmpl").text());

$("#evaluation").html(evalText(dataEval));

例子三:

3、for array iteration 数组

格式:

{{~data.array :value:index }}

...

{{~}}

数据源:{"array":["banana","apple","orange"]}

区域:

模板:

{{~it.array:value:index}}

{{= index+1 }}{{= value }}!

{{~}}

调用方式:

var dataArr = {"array":["banana","apple","orange"]};

var arrText = doT.template($("#arraystmpl").text());

$("#arrays").html(arrText(dataArr));

例子四:

4、{{? }} for conditionals 条件

格式:

{{? }} if

{{?? }} else if

{{??}} else

数据源:{"name":"Jake","age":31}

区域:

模板:

{{? !it.name }}

Oh, I love your name, {{=it.name}}!

{{?? !it.age === 0}}

Guess nobody named you yet!

{{??}}

You are {{=it.age}} and still dont have a name?

{{?}}

调用方式:

var dataEncode = {"uri":"http://bebedo.com/?keywords=Yoga","html":"

html元素
"};

var EncodeText = doT.template($("#encodetmpl").text());

$("#encode").html(EncodeText(dataEncode));

例子五:

5、for interpolation with encoding

数据源:{"uri":"http://bebedo.com/?keywords=Yoga"}

格式:

{{!it.uri}}

区域:

模板:

Visit {{!it.uri}} {{!it.html}}

调用方式:

var dataEncode = {"uri":"http://bebedo.com/?keywords=Yoga","html":"

html元素
"};

var EncodeText = doT.template($("#encodetmpl").text());

$("#encode").html(EncodeText(dataEncode));

例子六:

6、{{# }} for compile-time evaluation/includes and partials

{{## #}} for compile-time defines

数据源:{"name":"Jake","age":31}

区域:

模板:

{{##def.snippet:

{{=it.name}}
{{#def.joke}}

#}}

{{#def.snippet}}

{{=it.html}}

调用方式:

var dataPart = {"name":"Jake","age":31,"html":"

html元素
"};

var defPart = {"joke":"

{{=it.name}} who?
"};

var partText = doT.template($("#parttmpl").text(), undefined, defPart);

$("#part").html(partText(dataPart));

源地址:http://www.cnblogs.com/kuikui/p/3505768.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值