template 的使用
插件介绍:template 是一个高性能的JavaScript模板引擎。
插件特性:
1、性能卓越,执行速度快(mustache 与 tmpl 的20多倍);
2、支持运行时调试,可精准定位异常模板所在语句;
3、对 NodeJS Express 有很好的支持;
4、安全,默认对输出进行转义;
5、可在浏览器端实现按路径加载模板;
6、支持预编译,可将模板转换成为非常精简的 js 文件;
7、模板语句简介,无需前缀引用数据,拥有简洁版本和原生版本可供选择;
8、支持所有流行的浏览器;
开始使用(有两种语法, 此文章介绍的是简介语法)
1) artTemplate 模板必须使用一个type="text/html" 的 script 标签用来存放模板(标签中写的是HTML);
<script type="text/html"></script>
2) 开始编写自己的模板
<script id="model" type="text/html">
<h1>{{title}}</h1>
<ul>
{{each list as value index}}
<li>{{index+1}}、{{value}}</li>
{{/each}}
</ul>
</script>
3) 使用数据渲染模板
var data ={
title: '热爱的游戏',
list: ['LOL','王者农药','梦三国','魔兽争霸','其它']
}; var html = template('model',data);
document.getElementById('box').innerHTML = html
到了这一步,打开页面就可以看到效果了。
artTemplate 简洁语法介绍:
1) 使用之前需要引用简洁语法的版本,例如:
<script src="template.js"></script>
2) 表达式:
{{ 和 }} 符号包裹起来的语句则为模板的表达式。
3) 输出表达式:
对内容编码输出: {{ title }}
对内容不编码输出: {{ #title }}
区别:
// 假如有这样一段数据,title 内出现了标签
var data ={
title: '<i>热爱的</i>游戏',
list: ['LOL','王者农药','梦三国','魔兽争霸','其它']
}; {{ title }} // 显示内容为:<i>热爱的</i>游戏 {{ #title }} // 显示内容为:热爱的游戏
4) 条件表达式
<script id="model" type="text/html">
<h1>{{ title }}</h1>
<ul>
// 判断条件自定
{{if list.length>0}}
{{each list as value index}}
<li>{{index+1}}、{{value}}</li>
{{/each}}
{{else}}
<p>没有内容</p>
{{/if}}
</ul>
</script>
5) 遍历表达式
{{each list as value index}}
<li>{{index+1}}、{{value}}</li>
{{/each}} // 也可以被简写为
{{each list}}
<li>{{$index+1}}、{{$value}}</li>
{{/each}}
artTemplate 方法:
template 函数中有两个参数值。
第一个参数表示需要编译的模板(填写的是模板的 ID)
第二个参数是需要向模板填充的数据,返回值是编译之后的HTML字符串;
// 目前了解到此处
artTemplate 默认配置
示例:
<script id="people" type="text/html">
<h1>{{title}}</h1>
<ul>
{{if peos.length>0}}
{{each peos as p index}}
<li>
{{index+1}}、
选手姓名:<span>{{p.name}</span>
年龄:<span>{{p.age}}</span>
</li>
{{/each}}
{{else}}
<p>没有内容</p>
{{/if}}
</ul>
</script> <script>
var data2 ={
title: '喜欢的职业选手',
peos: [
{
name: "<b>Uzi</b>",
age: 20
},
{
name: 'Clearlove7',
age: 20
},
{
name: 'Korol',
age: 21
}
]
}
// 默认为true 不编译 输出为 <b>Uzi</b>
// false 编译 是否编码输出 HTML 字符
template.config("escape",false);
var html2 = template('people',data2);
document.getElementById('box2').innerHTML = html2;
</script>
template 的使用的更多相关文章
- 为.NET Core项目定义Item Template
作为这个星球上最强大的IDE,Visual Studio不仅仅提供了很多原生的特性,更重要的是它是一个可定制的IDE,比如自定义Project Template和Item Template就是一个非常 ...
- jQuery.template.js 简单使用
之前看了一篇文章<我们为什么要尝试前后端分离>,深有同感,并有了下面的评论: 我最近也和前端同事在讨论这个问题,比如有时候前端写好页面给后端了,然后后端把这些页面拆分成很多的 views, ...
- 2000条你应知的WPF小姿势 基础篇<69-73 WPF Freeze机制和Template>
在正文开始之前需要介绍一个人:Sean Sexton. 来自明尼苏达双城的软件工程师.最为出色的是他维护了两个博客:2,000ThingsYou Should Know About C# 和 2,00 ...
- tornado template
若果使用Tornado进行web开发可能会用到模板功能,页面继承,嵌套... 多页应用模板的处理多半依赖后端(SPA就可以动态加载局部视图),就算是RESTfull的API设计,也不妨碍同时提供部分模 ...
- 设计模式(九): 从醋溜土豆丝和清炒苦瓜中来学习"模板方法模式"(Template Method Pattern)
今天是五.四青年节,祝大家节日快乐.看着今天这标题就有食欲,夏天到了,醋溜土豆丝和清炒苦瓜适合夏天吃,好吃不上火.这两道菜大部分人都应该吃过,特别是醋溜土豆丝,作为“鲁菜”的代表作之一更是为大众所熟知 ...
- C++泛型编程:template模板
泛型编程就是以独立于任何特定类型的方式编写代码,而模板是C++泛型编程的基础. 所谓template,是针对“一个或多个尚未明确的类型”所编写的函数或类. 使用template时,可以显示的或隐示的将 ...
- 新手入门Underscore.js 中文(template)
Underscore.js是一个很精干的库,压缩后只有4KB.它提供了几十种函数式编程的方法,弥补了标准库的不足,大大方便了javaScript的编程.MVC框架Backbone.js就将这个库作为自 ...
- knockoutjs如何动态加载外部的file作为component中的template数据源
玩过knockoutjs的都知道,有一个强大的功能叫做component,而这个component有个牛逼的地方就是拥有自己的viewmodel和template, 比如下面这样: ko.compon ...
- JavaScript模板引擎artTemplate.js——template.helper()方法
上一篇文章我们已经讲到了helper()方法,但是上面的例子只是一个参数的写法,如果是多个参数,写法就另有区别了. <div id="user_info"></d ...
- linux下, 再次遇到使用thinkphp的模板标签时,报错used undefined function \Think\Template\simplexml_load_string() 是因为没有安装 php-xml包
linux下, 使用thinkphp的模板标签,如 eq, gt, volist defined, present , empty等 标签时, 报错: used undefined function ...
随机推荐
- leetcode-840-Magic Squares In Grid
题目描述: A 3 x 3 magic square is a 3 x 3 grid filled with distinct numbers from 1 to 9 such that each r ...
- 关于nginx的一个错误操作记录
今天在弄前后端同步的测试的时候,前端用Nginx代理访问后端接口,由于启动了多次nginx软件,没有将前几次启动的nginx进程关闭,导致在访问后端接口的request被挂起,过了半天也没有结果返回, ...
- Haskell优雅的快排实现
说得快速排序,基本是常用的排序当中速度最快的排序了,之前也用C和Java实现过,但是过程十分痛苦,更重要的是写完代码只记得过程却对实质的过程觉得隔了一层纱,有种说不出的感觉.刚刚看一下Haskell实 ...
- SVN解决冲突的方法
SVN管理代码工具在群组合作开发的过程中,若多人同时修改一个文件,就会出现冲突的情况. 冲突演示: 有A.B两个用户,他们各自从svn服务器中检出了file.txt文件,此时A.B.服务器三个地方的f ...
- spring定时任务详解
(一)在spring.xml里加入task的命名空间 xmlns:task="http://www.springframework.org/schema/task" http:// ...
- (转)DB2下载地址总结
原文:https://blog.csdn.net/huozengguang/article/details/58602910 DB2 v8.2,v9.1,v9.5,v9.7下载地址 下列都是完全版包含 ...
- mix使用本地依赖
在看elixir程序设计,书中讲到依赖设置,但是都是要联网,自己希望可以下载到本地电脑硬盘,然后项目要使用就用本地的,不要每次都要下载,因为天朝下载真的不稳 官方看到文档 {:deps_name,pa ...
- Java SE 基础知识
常量: 常量是一种标识符,它的值在运行期间恒定不变,并且常量在程序中只能被引用,而不能被重新赋值. 常量的命名规则: 1.在 Java 中,在变量声明中加入 final 关键字代表常量,加入 stat ...
- 话说C语言的关键字volatile
最近搞NVMe驱动需求分析,对volatile这个单词实在是再熟悉不过了. 而在C语言中,有一个关键字就叫做volatile, 其字面意思是"挥发性的, 不稳定的,可改变的". 那 ...
- 设计模式笔记-观察者(Observer)
观察者设计模式应该是比较简单的一个设计模式. 定义 定义了对象之间的一对多依赖,这样以来,当一个对象改变状态时,它的所有依赖者都会收到通知并自动更新. 简单理解就是: 当1个对象状态有所改变的时候,依 ...