php 掌握jquery,完全掌握jquery tmpl模板

之前用模板渲染都是用angular,无意间发现了jquery tmpl这种轻量级,其文档在这里,本文主要为大家带来一篇jquery tmpl模板(实例讲解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。

官方解释对该插件的说明:将匹配的第一个元素作为模板,render指定的数据,签名如下:

.tmpl([data,][options])

其中参数data的用途很明显:用于render的数据,可以是任意js类型,包括数组和对象。options一般情况下都是选项了,官方指出,此处的options是一个用户自定义的键值对的map,继承自tmplItem数据结构,适用于模板render动作期间。

在这里可以下载到最新的tmpl插件,值的一提的是,官方同时也说明了,tmpl目前是beta版,使用需谨慎..

下面是一个简单的例子

jquery template demo${ID}${Name}

$(function () {

var users = [{ ID: 'hao1', Name: 'Tony' }, { ID: 'hao2', Name: 'Mary hui'}];

$('#myTemplate').tmpl(users).appendTo('#rows');

});

body

{

padding: 10px;

}

table

{

border-collapse: collapse;

}

其效果如下

f62d2c75099b932ab61a6c9e5310ea94.png

定义模板时,推荐的方式为定义使用

做为模板的包装器,但定义方式并不只有这一种,你可以使用

编译缓存模板,在jQuery .tmpl()中,还可以将模板事先编译并缓存起来,然后在合适的时侯再使用,这对于一些数据嵌套是很有用的,如:

HTML:

JavaScript:

{{tmpl 'cached'}}

${ID}${Name}${Group}

$(function () {

var groupUsers = [{ ID: 'hao1', Name: 'Tony', Group: 'Administrators' }, { ID: 'hao2', Name: 'Mary hui', Group: 'Users'}];

$('#compile2').template('cached');

$('#compile1').tmpl(groupUsers).appendTo('#compileRows');

});

其效果如下

407f895756d18894e2f35cd6ecd7af44.png

$.template()方法,将一段Html编译为模板,示例:

JavaScript

var markup = '

${ID}${Name}';

$.template('template', markup);

$.tmpl('template', users).appendTo('#templateRows');

这样就可以将markup中定义的模板应用于templateRows对象。

jQuery .tmpl()的标签,表达式,属性:

${}:从前面的例子来看,这个标签的作用很明显了,相当于是占位符,但是它还有另一种写法{{= field}}如:

{{= ID}}{{= Name}}

必须要注意的是,"="号后必须跟一个空格,不然是没有效果的。

jQuery .tmpl()有两个比较有用的属性:$item、$data:

$item代表当前的模板;$data代表当前的数据。

Html

Javascript

${ID}${$data.Name}${$item.getLangs('; ')}

$(function () {

var userLangs = [{ ID: 'hao1', Name: 'Tony', Langs: ['PHP', 'Python'] }, { ID: 'hao2', Name: 'Mary hui', Langs: ['Java', 'C#']}];

$('#property').tmpl(userLangs, {

getLangs: function (separator) {

return this.data.Langs.join(separator);

}

}).appendTo('#propertyRows');

});

3134538434d9294d8cb0e7815a320265.png

{{each}}这个标签一看就知道是做循环用的了,用法如下:(关键词{{each Array}}、$value、$index)

HTML

Javascript

ID: ${ID};

Name: ${Name};

Langs:

{{each Langs}}

${$index + 1}:${$value}.

{{/each}}

$(function () {

var userLangs = [{ ID: 'hao1', Name: 'Tony', Langs: ['PHP', 'Python'] }, { ID: 'hao2', Name: 'Mary hui', Langs: ['Java', 'C#']}];

$('#eachList').tmpl(userLangs).appendTo('#ul_each');

});

其效果如下

42e9412a842c9b647385539adff5fc40.png

{{each}}还有另一种写法:

Javascript

ID: ${ID};

Name: ${Name};

Langs:

{{each(i,lang) Langs}}

${i+1}:${lang}

{{/each}}

作用和前一种是一样的。

{{if}}和{{else}},这两个标签应该一看就知道作用了,直接上示例:

Javascript

${ID}${Name}

{{if Langs.length > 1}}

${Langs.join('; ')}

{{else}}

${Langs}

{{/if}}

如果Langs数组元素超过1个,则用'; '连接起来,否则就直接显示Langs,效果如下:

27a6d40386c263f719856ce145a7af0c.png

{{html}},直接将对象属性值作为HTML代码替换占位符

$.tmplItem()方法,使用这个方法,可以获取从render出来的元素上重新获取$item,示例:

$('tbody').delegate('tr', 'click', function () {

var item = $.tmplItem(this);

alert(item.data.Name);

});

效果如下:

a94abdf31ecf394f571e50c7c22d1b18.png

相关推荐:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值