art-template 模板定义变量并更改变量值 不让其输出显示
在使用art-template.js出现如下的场景:
比如,循环体外面定义变量,并且在循环体内改变变量的值 但我又不想让其显示出来。
那我们一步一步的来实现以上的场景 看看会出现什么神奇的地方。
1.首先引入template-web.js
2.编写模板文件
<script id="template" type="text/html">
// 1.定义变量flag = false <br/>
{{set flag = false}}
// 2.循环 <br/>
{{each target list i}}
{{each target list2 j}}
{{if(i==j)}}
// 3.改变flag的值 <br/>
// 方案1(扑街):{{flag = true}} <br/>
// 直接在模板中这样写“flag = true”,这样最终的值到是改变了 ,
// 但是它也会在渲染过后显示在页面上。而我们只是想改变值而不想让其显示出来
//
// 方案二(扑街): {{set flag = true}}
// 我的理解是循环的作用域set了一个局部变量 ,
// 跟在循环体外面定义的flag 是两个不同的变量
// 所以这个方式虽然没有让其显示,但是却没有改变循环体定义的flag的值 没有起作用
// 经过各种查询资料 似乎都没有找到解决方案,本打算就此放弃。
// 通过各种尝试,并大胆推测:此模板是否支持“链式赋值”。自己也就尝试了一下。
// 成功了,不得不感叹art-template模板的强大,还有狠多有待挖掘。
// 记录一下,以免走弯路。
// 方案三(彩蛋):{{set flag1 = flag = true}}
{{set flag1 = flag = true}} // 关键一步 修改flag的值 而没有输出显示
{{/if}}
{{/each}}
{{/each}}
// 4. 输出flag值
{{flag}}
</script>
结果显示:
// 1.定义变量flag = false
// 2.循环
// 4. 输出flag值
true
已此记录, 方便交流
阅读 2.4k
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。