ART-TEMPLATE高性能模块渲染引擎

ART-TEMPLATE

高性能 JavaScript 模板引擎

介绍

art-template 是一个简约、超快的模板引擎。

它采用作用域预声明的技术来优化模板渲染速度,从而获得接近 JavaScript 极限的运行性能,并且同时支持 NodeJS 和浏览器。在线速度测试

特性

  1. 拥有接近 JavaScript 渲染极限的的性能
  2. 调试友好:语法、运行时错误日志精确到模板所在行;支持在模板文件上打断点(Webpack Loader)
  3. 支持 Express、Koa、Webpack
  4. 支持模板继承与子模板
  5. 浏览器版本仅 6KB 大小

安装

NPM

npm install art-template --save

在浏览器中实时编译

下载:template-web.js(gzip: 6kb)

安装了模板后可以直接在模块文件夹中引用 lib/template-web.js 文件

兼容

IE8+(IE8 需要补丁才能运行。示例

差异

因为浏览器不支持文件系统,所以 template(filename, data) 不支持传入文件路径,它内部使用 document.getElementById(filename).innerHTML 来获取模板,例如:

<script src="lib/template-web.js"></script>
<!--此处不能使用<script id="tpl-user" type="text/script">,否则浏览器会将其当做脚本进行解析-->
<script id="tpl-user" type="text/html">
// {
     {}} 语法被称之为mustache语法
{
     {
     if user}}
  <h2>{
     {
     user.name}}</h2>
{
     {
     /if}}
</script>

在浏览器中预编译

使用 Webpack 的 Loader: art-template-loader

Node模块引擎使用

  • 模板引起最早就是诞生于服务器领域,后来才发展到了前端。

  • 在需要使用的文件模块中加载 art-template

  • 只需要使用 require 方法加载就可以了:require('art-template')

var template = require('art-template')
var fs = require('fs')

  // 默认读取到的 data 是二进制数据
  // 而模板引擎的 render 方法需要接收的是字符串
  // 所以我们在这里需要把 data 二进制数据转为 字符串 才可以给模板引擎使用

// 读取文件
fs.readFile('./tpl.html', function(err, data){
   
    if(!err){
   
      // 根据模板名渲染模板。
      var result = template.render(data.toString(), {
   
        name: 'Jachie',
        age: 23,
        province: '四川',
        hobbies:[
          '敲代码',
          '写页面',
          '看博客'
        ],
        title: '我的标题'
      })
    }
    else 
      return console.log('文件读取出错')

    console.log(result)
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

空 白

停止的只会是自己,你得追逐世界

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值