1、介绍

新一代 javascript 模板引擎。

2、性能(引)

  1、性能卓越,执行速度通常是 Mustache 与 tmpl 的 20 多倍(性能测试)
  2、支持运行时调试,可精确定位异常模板所在语句(演示)
  3、对 NodeJS Express 友好支持
  4、安全,默认对输出进行转义、在沙箱中运行编译后的代码(Node版本可以安全执行用户上传的模板)
  5、支持include语句,可在浏览器端实现按路径加载模板
  6、支持预编译,可将模板转换成为非常精简的 js 文件
  7、模板语句简洁,无需前缀引用数据
  8、支持所有流行的浏览器

3、方法介绍

template(id, data)
根据 id 渲染模板。内部会根据document.getElementById(id)查找模板。
如果没有 data 参数,那么将返回一渲染函数。

template.compile(source, options)

将返回一个渲染函数。

var render = template.compile(tpl);//tpl是模板

tpl代码如下

{{each data as value index}}
<tr>
<td>{{index+1}}</td>
<td>{{value.a1}}</td>
<td class="tooltip" rel="{{value.a2}}"><p>{{value.a3}}</p></td>
<td><a href="">{{value.a4}}</a></td>
<td><a href="">{{value.a5}}</a></td>
<td><a href="">{{value.a6}}</a></td>
<td>{{value.a7}}</td>
<td>{{value.a8}}</td>
<td><a href="javascript:;" class="block"><span dataId="{{value.a9}}" class="block del-practice"></span></a></td>
</tr>
{{/each}}

template.render(source, options)

将返回渲染结果。同上返回的template.compile(source, options)函数

代码如下

我们拿var render = template.compile(tpl);返回的函数render来生成html页面

如下:

$('#ID').html(render(result));//result为后端返回的json数据

template.helper(name, callback)

添加辅助方法。

例如:(转)

template.helper('dateFormat', function (date, format) {

    date = new Date(date);

    var map = {
"M": date.getMonth() + 1, //月份
"d": date.getDate(), //日
"h": date.getHours(), //小时
"m": date.getMinutes(), //分
"s": date.getSeconds(), //秒
"q": Math.floor((date.getMonth() + 3) / 3), //季度
"S": date.getMilliseconds() //毫秒
};
format = format.replace(/([yMdhmsqS])+/g, function(all, t){
var v = map[t];
if(v !== undefined){
if(all.length > 1){
v = '0' + v;
v = v.substr(v.length-2);
}
return v;
}
else if(t === 'y'){
return (date.getFullYear() + '').substr(4 - all.length);
}
return all;
});
return format;
});

如何使用?

如下:

{{time | dateFormat:'yyyy年 MM月 dd日 hh:mm:ss'}}//模板中这么使用  time是一个字符串  dateFormat函数名

template.config(name, value)

更改引擎的默认配置。参数如下

openTag     String          {{            语法开始标签
closeTag     String          }}            语法结束标签
escape        Boolean        true         是否编码输出 HTML 字符
cache          Boolean        true         是否开启缓存(依赖 options 的 filename 字段)
compress     Boolean       false         是否压缩 HTML 多余空白字符

使用预编译
可突破浏览器限制,让前端模板拥有后端模板一样的同步“文件”加载能力:

按文件与目录组织模板

template('tpl/home/main', data)
模板支持引入子模板

{{include '../public/header'}}

基础不再详述下面介绍模板语法与原生语法的使用例子

4、语法使用

基础语法

<ul>
{{each result as value index}}
{{if index <= 2}}
<li class="item-ranking clearfix firstList {{if index == result.length-1}}last{{/if}}">
<img class="fl head-portrait" src="{{value.picUrl}}" onerror="javascript:this.src='people-error.png';"></img>
<div class="zz_big"></div>
<div class="fl modify-num">
<p class="ranking-name">
<span class="ell student-name" title="{{value.name}}">{{value.name}}</span>
<span class="student">已练习&nbsp;{{value.exerciseNum}}</span>
<div class="view-btn" data-id={{value.ID}} data-url="{{value.picUrl}}" data-num="{{index+1}}">查看</div>
</p>
</div>
</li>
{{else}}
<li class="item-ranking clearfix {{if index == result.length-1}}last{{/if}}">
<img class="fl head-portrait" src="{{value.picUrl}}" onerror="javascript:this.src='people-error.png';"></img>
<div class="zz_small"></div>
<div class="fl modify-num">
<p class="fl ranking-name">
<span class="ell student-name" title="{{value.name}}">{{value.name}}</span>
<span class="student">已练习&nbsp;{{value.exerciseNum}}</span>
</p>
</div>
<div class="view-btn1 fl" data-id={{value.ID}} data-url="{{value.picUrl}}" data-num="{{index+1}}">查看</div>
</li>
{{/if}}
{{/each}}
</ul>

模板语法支持基础的判断 但是高级的功能,比如js原生的方法是不支持的,下面介绍原生语法例子

原生语法

<%for(var key=0;key<data.length;key++){%>
<tr<%if(/失败/.test(data[key].result)){%> class="redbg" <%}%>>
<td><%=(key+1)%></td>
<td><%=data[key].a1%></td>
<td><%=data[key].a2%></td>
<td><%=data[key].a3%></td>
<td><%=data[key].a4 %></td>
<td><%=data[key].a5%></td>
<td>
<%if(data[key].a5 == "测试失败"){%>
<!--<button type="button" class="block recheck btn" dataID="<%=data[key].piGaiTopicId%>">ssss</button>-->
<%}%><%else{%>
<%=data[key].mark%>
<%}%>
</td>
</tr>
<%}%>

原生语法支持js的方法的使用和判断,这在灵活使用上很方便,可读性稍差了点。

artTemplate模板的更多相关文章

  1. artTemplate模板引擎学习实战

    在我的一篇关于智能搜索框异步加载数据的文章中,有博友给我留言,认为我手写字符串拼接效率过低,容易出错.在经过一段时间的摸索和学习之后,发现现在拼接字符串的方法都不在是自己去书写了,而是使用Javasc ...

  2. artTemplate模板引擎

    artTemplate模板引擎         <li>索引 {{i + 1}} :{{value}}</li>     {{/each}} </ul> </ ...

  3. 高性能前端 art-template 模板

    官网: https://aui.github.io/art-template/zh-cn/index.html nodejs 服务器端使用 第一步: 引入 art-template 的包 npm in ...

  4. django的小操作,查询效率up, 引用art-template模板+djangorestframework

    Part1: 提高查询效率newses = News.objects.select_related('category', 'author').get(id=1) # category和author字 ...

  5. thinkjs——art-template模板用法

    前言: 概述之前先附上此正式版介绍地址:https://github.com/aui/artTemplate  or http://www.jq22.com/jquery-info1097,可以再看下 ...

  6. ajax请求数据填充表格———使用art-template模板提高效率

    一.为什么要用art-template模板 在实习的一次项目中,因为需求中展示表格的字段有很多个,后端返回的也是json数据,这时候如果还是使用之前的字符串拼接,这样会开发得比较慢,而且容易出错,而且 ...

  7. nodejs中引入art-template模板

    使用Webstorm创建nodejs express应用时,默认使用的是jade或者ejs模板,对于不习惯这两种模板语法的人来说确实不是很方便.没关系,这里我们使用art-template模板引擎,使 ...

  8. koa art-template模板引擎的使用

    art-template 模板引擎介绍 art-template 是一个简约.超快的模板引擎. 它采用作用域预声明的技术来优化模板渲染速度,从而获得接近 JavaScript 极限的运行 性能,并且同 ...

  9. Node学习之(第三章:art-template模板引擎的使用)

    前言 大家之前都有使用过浏览器中js模板引擎,其实在Node.js中也可以使用模板引擎,最早使用模板引擎的概念是在服务端新起的. art-template art-template是一款高性能的Jav ...

  10. Express 中配置使用 art-template模板引擎

    art-template 官网 https://aui.github.io/art-template/ 安装: npm install --save art-template npm install ...

随机推荐

  1. struts2-dojo-plugin-2.3.1.2.jar!/struts-plugin.xml:29:119

    Unable to load configuration. - bean - jar:file:/D:/code_workspace/SSHWorkSpace3/.metadata/.plugins/ ...

  2. Android开发系列(十九个):至SimpleAdapter设置样式

    Adapter任务:在数据adapter处理后做.展会上的观点 对于一般ArrayAdapter供.传递给ArrayAdapter之后就能够在视图上用一个列表显示出这个字符串数组. 比例如以下边的代码 ...

  3. 第三十 访问财富进退自如 —Spring交易管理

    6月16日本,明确. "应该留给追穷寇勇,不可沽名学霸王.天若有情天亦老,人间正道是沧桑." 有始有终.有往有还.进退自如乃Spring事务管理之道,也是万物生生不息.和谐共处之道 ...

  4. ORA-12638: 无法检索身份证明 解决的方法

    the NTS option makes the Oracle client attempt to use your current Windows domain credentials to aut ...

  5. python基础课程_学习笔记21:文件和材料

    文件和材料 打开文件 open功能是用来打开文件,语法例如,下面的: open([name[,mode[,buffering]]) open函数使用一个文件名称作为唯一的强制參数,然后返回一个文件对象 ...

  6. Android Loader使用,屏幕解锁,重复荷载

    正在使用AsyncTaskLoader时间.当手机被解锁,重复加载数据,码,如以下: static class CouponShopQueryLoader extends AsyncTaskLoade ...

  7. Ubuntu Server 14.04 LTS(64bit)已安装 weblogic Server 12c(12.1.3) Zip Distribution

    这里说的对Ubuntu Server 14.04 LTS(64bit)已安装weblogic Server 12c(12.1.3) Zip Distribution遇到的问题.至于Windows什么好 ...

  8. oracle_深刻理解数据库的启动和关闭

    Oracle数据库提供了几种不同的数据库启动和关闭方式,本文将详细介绍这些启动和关闭方式之间的区别以及它们各自不同的功能. 一.启动和关闭Oracle数据库 对于大多数Oracle DBA来说,启动和 ...

  9. Android开发手册 (Android的手工教程MtAndroid开发手册)

    放出版许可协议 1.0 或者更新版本号. 未经版权全部者明白授权,禁止发行本文档及其被实质上改动的版本号.  未经版权全部者事先授权.禁止将此作品及其衍生作品以标准(纸质)书籍形式发行. 假设有兴趣再 ...

  10. 浏览器扩展系列————在WPF中定制WebBrowser快捷菜单

    原文:浏览器扩展系列----在WPF中定制WebBrowser快捷菜单 关于如何定制菜单可以参考codeproject上的这篇文章:http://www.codeproject.com/KB/book ...