简介

artTemplate是新一代的高性能JavaScript模板引擎。

 

插件官网

http://aui.github.io/art-template/zh-cn/docs/syntax.html

 

插件下载

完整版:https://github.com/aui/art-template

浏览器版:https://github.com/aui/art-template/tree/master/lib

 

简单使用

① 引入template-web.js

<script type="text/javascript" src="template-web.js"></script>

 

② 定义数据结果渲染区

<div id="content"><div>

 

③ 定义数据模板

    使用一个type="text/html"的script标签定义数据存放模板

<script id="data-tpl" type="text/html">
<h1>{{title}}</h1>
<ul>
    {{each list value i}}
        <li>索引 {{i + 1}} :{{value}}</li>
    {{/each}}
</ul>
</script>

 

④ 渲染数据

var data = {
    title: '标签',
    list: ['文艺', '博客', '摄影', '电影', '民谣', '旅行', '吉他']
};
var html = template('data-tpl', data);
document.getElementById('content').innerHTML = html;

 

基础语法

变量

标准语法:

{{set temp = data.sub.content}}

原始语法: 

<% var temp = data.sub.content; %>

 

变量输出(标准语法 + 原始语法)

{{value}}               -- 输出单个变量
<%= value %>

{{data.key}}            -- 输出对象中的某个属性
<%= data.key %>

{{data['key']}}         -- 输出数组中的某个属性
<%= data['key'] %>

{{a ? b : c}}           -- 三目运算
<%= a ? b : c %>

{{a || b}}              -- 为某个变量设置默认值b
<%= a || b %>

{{a + b}}               -- 表达式运算
<%= a + b %>

{{@ value }}            -- 原样输出(变量前加@或者#符号)
<%- value %>            -- 原文输出语句不会对 HTML 内容进行转义处理

 

条件判断

标准语法:

{{if value}} ... {{/if}}

{{if v1}} ... {{else}} ... {{/if}}

{{if v1}} ... {{else if v2}} ... {{/if}}

 

原始语法: 

<% if (value) { %> ... <% } %>
<% if (v1) { %> ... <% } else { %> ... <% } %>
<% if (v1) { %> ... <% } else if (v2) { %> ... <% } %>

 

循环遍历

无论数组或者对象都可以用 each 进行遍历。

标准语法:

形式一(默认key和value)

{{each target}}

{{$index}} {{$value}}

{{/each}}

形式二(自定义key和value)

{{each target val key}}...{{/each}}

 

原始语法: 

<% for(var i = 0; i < target.length; i++){ %>
    <%= i %> <%= target[i] %>
<% } %>

 

 

API

  • template(id, data)

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

  • template.compile(source, options)

可以直接在js中使用字符串作为模板内容进行编译,之后将返回一个渲染函数。options参数猜想应该是局部配置

  • template.render(source, options)

如果直接使用和compile一样起编译作用,一般不直接使用,编译后返回的就是这个函数。渲染编译后的模板并返回结果。options参数猜想应该是局部配置

  • template.helper(name, callback)

添加辅助方法,作用于模板中。name方法名,callback回调函数

 

posted on 2019-11-25 12:02  FuYingju  阅读(96)  评论(0编辑  收藏  举报