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

首頁 > 語言 > JavaScript > 正文

JavaScript模板引擎應(yīng)用場景及實現(xiàn)原理詳解

2024-05-06 15:27:19
字體:
供稿:網(wǎng)友

本文實例講述了JavaScript模板引擎應(yīng)用場景及實現(xiàn)原理。分享給大家供大家參考,具體如下:

一、應(yīng)用場景

以下應(yīng)用場景可以使用模板引擎:

1、如果你有動態(tài)ajax請求數(shù)據(jù)并需要封裝成視圖展現(xiàn)給用戶,想要提高自己的工作效率。
2、如果你是拼串族或者數(shù)組push族,迫切的希望改變現(xiàn)有的書寫方式。
3、如果你在頁面布局中,存在共性模塊和布局,你可以提取出公共模板,減少維護(hù)的數(shù)量。

二、實現(xiàn)原理

不同模板間實現(xiàn)原理大同小異,各有優(yōu)缺,請按需選擇,以下示例以artTemplate模板引擎來分析。

2.1 模板存放

模板一般都是放置到textarea/input等表單控件,或者script[type="text/html"]等標(biāo)簽中,如下:

<script id="test" type="text/html"> {{if isAdmin}} <h1>{{title}}</h1> <ul>   {{each user as name i}}     <li> {{i + 1}} :{{name}}</li>   {{/each}} </ul> {{/if}}</script>//textarea或input則取value,其它情況取innerHTML

2.2 模板函數(shù)

一般都是templateFun("id", data);其中id為存放模板字符串的元素id,data為需要裝載的數(shù)據(jù)。

2.3 模板獲取

一般都是通過ID來獲取,document.getElementById("ID"):

//textarea或input則取value,其它情況取innerHTMLvar html = /^(textarea|input)$/i.test(element.nodeName) ? element.value : element.innerHTML;

2.4 模板解析——處理html語句和邏輯語句及其他格式化處理

這步的主要操作其實多余的空格,解析出html元素和邏輯語句及關(guān)鍵字。例如:artTemplate.js中的代碼實現(xiàn):

defaults.parser = function (code, options) {  // var match = code.match(/([/w/$]*)(/b.*)/);  // var key = match[1];  // var args = match[2];  // var split = args.split(' ');  // split.shift();  //if isAdmin  code = code.replace(/^/s/, '');  //["if", "isAdmin"]  var split = code.split(' ');  //if  var key = split.shift();  //isAdmin  var args = split.join(' ');  switch (key) {    case 'if':      //if(isAdmin){      code = 'if(' + args + '){';      break;    case 'else':      if (split.shift() === 'if') {        split = ' if(' + split.join(' ') + ')';      } else {        split = '';      }      code = '}else' + split + '{';      break;    case '/if':      code = '}';      break;    case 'each':      var object = split[0] || '$data';      var as   = split[1] || 'as';      var value = split[2] || '$value';      var index = split[3] || '$index';      var param  = value + ',' + index;      if (as !== 'as') {        object = '[]';      }      code = '$each(' + object + ',function(' + param + '){';      break;    case '/each':      code = '});';      break;    case 'echo':      code = 'print(' + args + ');';      break;    case 'print':    case 'include':      code = key + '(' + split.join(',') + ');';      break;            
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 武清区| 远安县| 孝感市| 祁连县| 太康县| 张掖市| 安吉县| 嘉定区| 秦皇岛市| 余庆县| 安义县| 库伦旗| 德钦县| 潼南县| 灵璧县| 邵阳县| 北票市| 禄丰县| 武平县| 广西| 灯塔市| 博罗县| 临泽县| 阿克陶县| 东阿县| 遵义市| 牟定县| 和硕县| 蓝田县| 石屏县| 菏泽市| 阿勒泰市| 大埔县| 乳源| 靖远县| 博罗县| 聊城市| 射阳县| 锡林浩特市| 固原市| 建水县|