国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

JavaScript模板引擎Template.js使用詳解

2019-11-19 18:28:40
字體:
供稿:網(wǎng)友

template.js 一款 JavaScript 模板引擎,簡單,好用。提供一套模板語法,用戶可以寫一個模板區(qū)塊,每次根據(jù)傳入的數(shù)據(jù),生成對應(yīng)數(shù)據(jù)產(chǎn)生的HTML片段,渲染不同的效果。https://github.com/aui/artTemplate

1、特性

(1)、性能卓越,執(zhí)行速度通常是 Mustache 與 tmpl 的 20 多倍(性能測試)(2)、支持運(yùn)行時調(diào)試,可精確定位異常模板所在語句(演示)

(3)、對 NodeJS Express 友好支持(4)、安全,默認(rèn)對輸出進(jìn)行轉(zhuǎn)義、在沙箱中運(yùn)行編譯后的代碼(Node版本可以安全執(zhí)行用戶上傳的模板)

(5)、支持include語句

(6)、可在瀏覽器端實現(xiàn)按路徑加載模板(詳情)

(7)、支持預(yù)編譯,可將模板轉(zhuǎn)換成為非常精簡的 js 文件

(8)、模板語句簡潔,無需前綴引用數(shù)據(jù),有簡潔版本與原生語法版本可選

(9)、支持所有流行的瀏覽器

2、語法

(1)、使用

引用簡潔語法的引擎版本,例如: <script src="dist/template.js"></script> 

(2)、表達(dá)式

{{ 與 }} 符號包裹起來的語句則為模板的邏輯表達(dá)式。

(3)、輸出表達(dá)式

對內(nèi)容編碼輸出: {{content}} 
不編碼輸出: {{#content}} 
編碼可以防止數(shù)據(jù)中含有 HTML 字符串,避免引起 XSS 攻擊。

(4)、條件表達(dá)式

{{if admin}}  <p>admin</p> {{else if code > 0}}  <p>master</p> {{else}}  <p>error!</p> {{/if}} 

(5)、遍歷表達(dá)式

無論數(shù)組或者對象都可以用 each 進(jìn)行遍歷。

{{each list as value index}}  <li>{{index}} - {{value.user}}</li> {{/each}} 

亦可以被簡寫:

{{each list}}  <li>{{$index}} - {{$value.user}}</li> {{/each}} 

(6)、模板包含表達(dá)式

用于嵌入子模板。

{{include 'template_name'}} 

子模板默認(rèn)共享當(dāng)前數(shù)據(jù),亦可以指定數(shù)據(jù):{{include 'template_name' news_list}} 

(7)、輔助方法

使用template.helper(name, callback)注冊公用輔助方法:

template.helper('dateFormat', function (date, format) {  // ..  return value; }); 

模板中使用的方式: {{time | dateFormat:'yyyy-MM-dd hh:mm:ss'}} 
支持傳入?yún)?shù)與嵌套使用: {{time | say:'cd' | ubb | link}} 

3、實例

<!DOCTYPE HTML> <html> <head> <meta charset="UTF-8"> <title>basic-demo</title> <script src="../dist/template.js"></script> </head> <body> <div id="content"></div> <script id="test" type="text/html"> {{if isAdmin}} <h1>{{title}}</h1> <ul>  {{each list as value i}}   <li>索引 {{i + 1}} :{{value}}</li>  {{/each}} </ul> {{/if}} </script> <script> var data = {  title: '基本例子',  isAdmin: true,  list: ['文藝', '博客', '攝影', '電影', '民謠', '旅行', '吉他'] }; var html = template('test', data); document.getElementById('content').innerHTML = html; </script> </body> </html>

 

<!DOCTYPE HTML> <html> <head> <meta charset="UTF-8"> <title>no escape-demo</title> <script src="../dist/template.js"></script> </head>  <body>  <h1>不轉(zhuǎn)義HTML</h1>  <div id="content"></div>  <script id="test" type="text/html">  <p>不轉(zhuǎn)義:{{#value}}</p>  <p>默認(rèn)轉(zhuǎn)義: {{value}}</p>  </script>   <script>  var data = {   value: '<span style="color:#F00">hello world!</span>'  };  var html = template('test', data);  document.getElementById('content').innerHTML = html;  </script> </body> </html> 

<!DOCTYPE HTML> <html> <head> <meta charset="UTF-8"> <title>include-demo</title> <script src="../dist/template.js"></script> </head>  <body> <div id="content"></div> <script id="test" type="text/html"> <h1>{{title}}</h1> {{include 'list'}} </script> <script id="list" type="text/html"> <ul>  {{each list as value i}}   <li>索引 {{i + 1}} :{{value}}</li>  {{/each}} </ul> </script>  <script> var data = {  title: '嵌入子模板',  list: ['文藝', '博客', '攝影', '電影', '民謠', '旅行', '吉他'] }; var html = template('test', data); document.getElementById('content').innerHTML = html; </script> </body> </html> 

<!DOCTYPE HTML> <html> <head> <meta charset="UTF-8"> <title>helper-demo</title> <script src="../dist/template.js"></script> </head>  <body> <h1>輔助方法</h1> <div id="content"></div> <script id="test" type="text/html"> {{time | dateFormat:'yyyy年 MM月 dd日 hh:mm:ss'}} </script>  <script> /**  * 對日期進(jìn)行格式化,  * @param date 要格式化的日期  * @param format 進(jìn)行格式化的模式字符串  *  支持的模式字母有:  *  y:年,  *  M:年中的月份(1-12),  *  d:月份中的天(1-31),  *  h:小時(0-23),  *  m:分(0-59),  *  s:秒(0-59),  *  S:毫秒(0-999),  *  q:季度(1-4)  * @return String  * @author yanis.wang  * @see http://yaniswang.com/frontend/2013/02/16/dateformat-performance/  */ template.helper('dateFormat', function (date, format) {   if (typeof date === "string") {   var mts = date.match(/(//Date(/d+)//)/);   if (mts && mts.length >= 3) {    date = parseInt(mts[2]);   }  }  date = new Date(date);  if (!date || date.toUTCString() == "Invalid Date") {   return "";  }   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; });  // --------  var data = {  time: 1408536771253, }; var html = template('test', data); document.getElementById('content').innerHTML = html; </script> </body> </html> 

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 南部县| 辽中县| 黎川县| 乡城县| 崇左市| 武安市| 磴口县| 万年县| 曲阳县| 大宁县| 雷波县| 山西省| 南开区| 无极县| 海宁市| 瑞金市| 板桥市| 上饶县| 吉首市| 尉氏县| 新巴尔虎左旗| 马龙县| 伊宁市| 张家港市| 耿马| 沈丘县| 湟源县| 瓦房店市| 武邑县| 常宁市| 彝良县| 巴彦淖尔市| 芷江| 手游| 新绛县| 诸城市| 遂昌县| 太保市| 秀山| 嘉善县| 丹寨县|