JsRender for object语法简介
作者:bea
本文简要讲述了JsRender for object的基本语法。分享给大家供大家参考。具体如下: JsRender 作为一款JavaScript模版引擎,必不可少的会有循环功能,也就是for,但由于JsRender过于灵活,for竟然可以接受object作为循环对象。 {{for Array}}和{{for Object}}都是允许的,{{for Array}}大家都能理解,就是遍历一个数组,逐个取出每个元素。但{{for Object}}就有点让人匪夷所思了,而且官方文档
本文简要讲述了JsRender for object的基本语法。分享给大家供大家参考。具体如下: JsRender 作为一款JavaScript模版引擎,必不可少的会有循环功能,也就是for,但由于JsRender过于灵活,for竟然可以接受object作为循环对象。
{{for Array}}和{{for Object}}都是允许的,{{for Array}}大家都能理解,就是遍历一个数组,逐个取出每个元素。但{{for Object}}就有点让人匪夷所思了,而且官方文档只是举了个没什么帮助的例子,其他无任何说明。
刚开始小菜以为{{for Object}}的用意是遍历该Object的所有属性,但仔细一想,这个功能{{props Object}}已经实现了,props标签的作用就是遍历Object所有属性,有多少个属性,就循环多少次,每次循环都会有两个隐藏的属性:key,prop,key代表属性名,prop代表属性值,用起来非常方便。
实际上,{{for Object}}并不是循环,它可以理解成进入(Into),也就是说进入到Object环境中,把当前的上下文设置为Object,类似于Handlebars.js中的with。
举个例子:
data:
代码如下:
{
"title": "The A team",
"members": [
{
"name": "Pete",
"city": "members_city",
"address": {
"city": "address_city",
"city1": "address_city1",
"city2": "address_city2"
}
}
]
}
template markup:
代码如下:
{{for members}}
{{for address}}
<p>.{{:city}}</p>
{{/for}}
{{/for}}
result:
代码如下:
address_city
从结果可以看出,虽然members的item下也有city属性,但由于通过{{for address}}进入到了address指向的Object中,{{:city}}直接从address中获取了。
同时,address有三个属性,但结果只输出了一行,证明{{for Object}}是不会循环的,仅仅是切换一下this。
希望本文所述对大家JsRender程序设计的学习有所帮助。
有用 | 无用
{{for Array}}和{{for Object}}都是允许的,{{for Array}}大家都能理解,就是遍历一个数组,逐个取出每个元素。但{{for Object}}就有点让人匪夷所思了,而且官方文档只是举了个没什么帮助的例子,其他无任何说明。
刚开始小菜以为{{for Object}}的用意是遍历该Object的所有属性,但仔细一想,这个功能{{props Object}}已经实现了,props标签的作用就是遍历Object所有属性,有多少个属性,就循环多少次,每次循环都会有两个隐藏的属性:key,prop,key代表属性名,prop代表属性值,用起来非常方便。
实际上,{{for Object}}并不是循环,它可以理解成进入(Into),也就是说进入到Object环境中,把当前的上下文设置为Object,类似于Handlebars.js中的with。
举个例子:
data:
代码如下:
{
"title": "The A team",
"members": [
{
"name": "Pete",
"city": "members_city",
"address": {
"city": "address_city",
"city1": "address_city1",
"city2": "address_city2"
}
}
]
}
template markup:
代码如下:
{{for members}}
{{for address}}
<p>.{{:city}}</p>
{{/for}}
{{/for}}
result:
代码如下:
address_city
从结果可以看出,虽然members的item下也有city属性,但由于通过{{for address}}进入到了address指向的Object中,{{:city}}直接从address中获取了。
同时,address有三个属性,但结果只输出了一行,证明{{for Object}}是不会循环的,仅仅是切换一下this。
希望本文所述对大家JsRender程序设计的学习有所帮助。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- 一款基jquery超炫的动画导航菜单可响应单击事件
- 加载列表时jquery获取ul中第一个li的属性
- 基于jquery固定于顶部的导航响应浏览器滚动条事件
- jQuery ajax serialize() 方法使用示例
- js获取UserControl内容为拼html时提供方便
- Javscript调用iframe框架页面中函数的方法
- js实现文章文字大小字号功能完整实例
- js中confirm实现执行操作前弹出确认框的方法
- js实现按钮加背景图片常用方法
- js实现网页随机切换背景图片的方法
- JS获取浏览器语言动态加载JS文件示例代码
- 一个检测表单数据的JavaScript实例
- JS 打印功能代码可实现打印预览、打印设置等
- 使用JQ来编写最基本的淡入淡出效果附演示动画
- Jquery修改页面标题title其它JS失效的解决方法
- jQuery实现响应浏览器缩放大小并改变背景颜色
- Thinkphp模板没有解析直接原样输出的解决方法
- 使用JS实现jQuery的addClass, removeClass, hasClass函数功能
- JsRender实用入门教程