art文档为什么不能html,artTemplate

3f7da3a39877b549ffd36d6edee55bb4.png

3efc3516b7ecb765a1f067c294640f12.png

插件描述:高性能JavaScript模板引擎

artTemplate-3.0

新一代 javascript 模板引擎

目录特性

快速上手

模板语法

方法

NodeJS

使用预编译

更新日志

授权协议

特性性能卓越,执行速度通常是 Mustache 与 tmpl 的 20 多倍(性能测试)

支持运行时调试,可精确定位异常模板所在语句(演示)

对 NodeJS Express 友好支持

安全,默认对输出进行转义、在沙箱中运行编译后的代码(Node版本可以安全执行用户上传的模板)

支持include语句

可在浏览器端实现按路径加载模板(详情)

支持预编译,可将模板转换成为非常精简的 js 文件

模板语句简洁,无需前缀引用数据,有简洁版本与原生语法版本可选

支持所有流行的浏览器

快速上手

编写模板

使用一个type="text/html"的script标签存放模板:

{{title}}

{{each list as value i}}

索引 {{i + 1}} :{{value}}

{{/each}}

渲染模板var data = {

title: '标签',

list: ['文艺', '博客', '摄影', '电影', '民谣', '旅行', '吉他']

};

var html = template('test', data);

document.getElementById('content').innerHTML = html;

模板语法

有两个版本的模板语法可以选择。

简洁语法

推荐使用,语法简单实用,利于读写。{{if admin}}

{{include 'admin_content'}}

{{each list}}

{{$index}}. {{$value.user}}

{{/each}}

{{/if}}

原生语法

下载

方法

template(id, data)

根据 id 渲染模板。内部会根据document.getElementById(id)查找模板。

如果没有 data 参数,那么将返回一渲染函数。

template.compile(source, options)

将返回一个渲染函数。演示

template.render(source, options)

将返回渲染结果。

template.helper(name, callback)

添加辅助方法。

例如时间格式器:演示

template.config(name, value)

更改引擎的默认配置。openTagString'{{'逻辑语法开始标签

closeTagString"}}"逻辑语法结束标签

escapeBooleantrue是否编码输出 HTML 字符

cacheBooleantrue是否开启缓存(依赖 options 的 filename 字段)

compressBooleanfalse是否压缩 HTML 多余空白字符

使用预编译

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

一、按文件与目录组织模板template('tpl/home/main', data)

二、模板支持引入子模板{{include '../public/header'}}

基于预编译:可将模板转换成为非常精简的 js 文件(不依赖引擎)

使用同步模板加载接口

支持多种 js 模块输出:AMD、CMD、CommonJS

支持作为 GruntJS 插件构建

前端模板可共享给 NodeJS 执行

自动压缩打包模板

预编译工具:TmodJS

NodeJS

安装npm install art-template

使用var template = require('art-template');

var data = {list: ["aui", "test"]};

var html = template(__dirname + '/index/main', data);

配置

NodeJS 版本新增了如下默认配置:baseString''指定模板目录

extnameString'.html'指定模板后缀名

encodingString'utf-8'指定模板编码

配置base指定模板目录可以缩短模板的路径,并且能够避免include语句越级访问任意路径引发安全隐患,例如:template.config('base', __dirname);

var html = template('index/main', data)

NodeJS + Expressvar template = require('art-template');

template.config('base', '');

template.config('extname', '.html');

app.engine('.html', template.__express);

app.set('view engine', 'html');

//app.set('views', __dirname + '/views');

运行 demo:node demo/node-template-express.js若使用 js 原生语法作为模板语法,请改用 require('art-template/node/template-native.js')

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值