jq tmpl输出编码html,jquery tmpl模板(实例讲解)

之前用模板渲染都是用angular,无意间发现了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;

}

其效果如下

10a8a3d0bbc65b2b6d202c6e212f6fe4.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');

});

其效果如下

8ba22eff2a53d8910ab6d3bc514ded82.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');

});

ee26862e00aad2ac19df7ed8549e727c.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');

});

其效果如下

c1dcea69266dd47d99f783795eedf6e7.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,效果如下:

b25c4761184f72bc4a3212dc02f94100.png

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

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

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

var item = $.tmplitem(this);

alert(item.data.name);

});

效果如下:

a6f9418d8747262eff5ac6ffed0e4fe0.png

以上这篇jquery tmpl模板(实例讲解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持萬仟网。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
jQuery tmpl是一个jQuery插件,用于在客户端生成和渲染HTML模板。它提供了一种简洁和灵活的方式来处理数据和模板的结合。通过使用jQuery tmpl,你可以通过将数据与HTML模板结合来动态生成页面内容。 使用jQuery tmpl,你可以在HTML中定义模板,并使用JavaScript来填充模板中的数据。它支持条件语句、循环、变量和表达式等常见的模板功能。同时,它还提供了一些内置的函数和过滤器,用于处理数据和格式化输出。 以下是一个简单的示例,演示了如何使用jQuery tmpl来生成动态内容: HTML模板: ```html <script id="template" type="text/x-jQuery-tmpl"> <h1>${title}</h1> <<p>${description}</p> </script> ``` JavaScript代码: ```javascript // 填充数据 var data = { title: "Welcome to my website", description: "This is a sample template using jQuery tmpl" }; // 使用模板生成HTML var html = $("#template").tmpl(data); // 将生成的HTML插入到页面中 $("#content").html(html); ``` 在上面的示例中,我们首先定义了一个HTML模板,并使用`${}`语法指定了模板中需要填充的数据。然后,我们使用JavaScript代码创建了一个包含要填充的数据的对象。最后,我们使用`tmpl()`函数将数据应用于模板,并将生成的HTML插入到页面的指定位置。 这只是一个简单的示例,jQuery tmpl还支持更复杂的模板和数据操作。你可以查阅相关文档了解更多信息和用法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值