亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

JavaScript模板引擎應用場景及實現原理詳解

2024-05-06 16:47:07
字體:
來源:轉載
供稿:網友

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

一、應用場景

以下應用場景可以使用模板引擎:

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

二、實現原理

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

2.1 模板存放

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

<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 模板函數

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

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元素和邏輯語句及關鍵字。例如:artTemplate.js中的代碼實現:

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;

例如上例中:”{{if isAdmin}}”最終被解析成”if(isAdmin){”,”{{/if}}“被解析成“}”。

2.5 模板編譯——字符串拼接成生成函數的過程

這步的主要操作就是字符串的拼接成生成函數,看看artTemplate的部分源碼:

function compiler (source, options) {  /*  openTag: '<%',  // 邏輯語法開始標簽  closeTag: '%>',  // 邏輯語法結束標簽  escape: true,   // 是否編碼輸出變量的 HTML 字符  cache: true,   // 是否開啟緩存(依賴 options 的 filename 字段)  compress: false, // 是否壓縮輸出  parser: null   // 自定義語法格式器 @see: template-syntax.js  */  var debug = options.debug;  var openTag = options.openTag;  var closeTag = options.closeTag;  var parser = options.parser;  var compress = options.compress;  var escape = options.escape;  var line = 1;  var uniq = {$data:1,$filename:1,$utils:1,$helpers:1,$out:1,$line:1};  //isNewEngin在6-8返回undefined  var isNewEngine = ''.trim;// '__proto__' in {}  var replaces = isNewEngine  ? ["$out='';", "$out+=", ";", "$out"]  : ["$out=[];", "$out.push(", ");", "$out.join('')"];  var concat = isNewEngine    ? "$out+=text;return $out;"    : "$out.push(text);";  var print = "function(){"  +   "var text=''.concat.apply('',arguments);"  +    concat  + "}";  var include = "function(filename,data){"  +   "data=data||$data;"  +   "var text=$utils.$include(filename,data,$filename);"  +    concat  +  "}";  var headerCode = "'use strict';"  + "var $utils=this,$helpers=$utils.$helpers,"  + (debug ? "$line=0," : "");  var mainCode = replaces[0];  var footerCode = "return new String(" + replaces[3] + ");"  // html與邏輯語法分離  forEach(source.split(openTag), function (code) {    code = code.split(closeTag);    var $0 = code[0];    var $1 = code[1];    // code: [html]    if (code.length === 1) {      mainCode += html($0);    // code: [logic, html]    } else {      mainCode += logic($0);      if ($1) {        mainCode += html($1);      }    }  });  var code = headerCode + mainCode + footerCode;

上例中模板中的模板字符串代碼會被拼接成如下字符串:

'use strict';var $utils  = this, $helpers = $utils.$helpers, isAdmin = $data.isAdmin, $escape = $utils.$escape, $each  = $utils.$each, user   = $data.user, name   = $data.name, i    = $data.i, $out   = '';if (isAdmin) { $out += '/n/n <h1>'; $out += $escape(title); $out += '</h1>/n <ul>/n   '; $each(user, function(name, i) { $out += '/n     <li>'; $out += $escape(i + 1); $out += ' :'; $out += $escape(name); $out += '</li>/n   '; }); $out += '/n </ul>/n/n ';}return new String($out);

然后會被生成如下函數:

var Render = new Function("$data", "$filename", code);/*Outputs:function anonymous($data, $filename) { 'use strict'; var $utils  = this, $helpers = $utils.$helpers, isAdmin = $data.isAdmin, $escape = $utils.$escape, $each  = $utils.$each, user   = $data.user, name   = $data.name, i    = $data.i, $out   = ''; if (isAdmin) { $out += '/n/n <h1>'; $out += $escape(title); $out += '</h1>/n <ul>/n   '; $each(user, function(name, i) {  $out += '/n     <li>';  $out += $escape(i + 1);  $out += ' :';  $out += $escape(name);  $out += '</li>/n   '; }); $out += '/n </ul>/n/n '; } return new String($out);} */console.log(Render);

2.5 裝載數據,視圖呈現

/*Outputs:<h1>User lists</h1><ul>  <li>1 :zuojj</li>  <li>2 :Benjamin</li>  <li>3 :John</li>  <li>4 :Rubby</li>  <li>5 :Handy</li>  <li>6 :CIMI</li></ul>*/console.log(new Render(data, filename) + '');//對象轉換為字符串return new Render(data, filename) + '';

三、常見JavaScript模板引擎及測試對比

artTemplate —— 高性能JavaScript模板引擎(騰訊CDC) 
Velocity.js —— 來自淘寶的JS 模板引擎
JavaScript Templates —— 輕量、快速、強大、無依賴模板引擎
Juicer —— 高效、輕量的Javascript模板引擎
mustache.js —— Logic-less {{mustache}} templates with JavaScript

希望本文所述對大家JavaScript程序設計有所幫助。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品自拍偷拍| 国产精品视频区1| 国产日韩在线观看av| 91亚洲永久免费精品| 欧美一级电影久久| 亚洲精品视频网上网址在线观看| 日韩在线播放一区| 欧美高清第一页| 成人精品一区二区三区| 日韩精品视频观看| 亚洲一区二区久久久久久久| 庆余年2免费日韩剧观看大牛| 欧美乱妇高清无乱码| 成人羞羞国产免费| 久久精视频免费在线久久完整在线看| 欧美天天综合色影久久精品| 91免费精品国偷自产在线| 国产精品观看在线亚洲人成网| 久久精品99久久久久久久久| 日韩综合中文字幕| 精品夜色国产国偷在线| 性视频1819p久久| 91伊人影院在线播放| 亚洲人精品午夜在线观看| 亚洲欧美国产精品va在线观看| 亚洲成人精品av| 日韩综合中文字幕| 亚洲综合中文字幕68页| 久久免费精品日本久久中文字幕| 成人精品一区二区三区电影黑人| 亚洲精品日韩丝袜精品| 亚洲xxx自由成熟| 日本久久91av| 久久精品一本久久99精品| 国产91九色视频| 亚洲国内精品视频| 26uuu久久噜噜噜噜| 亚洲人a成www在线影院| 欧美日韩国产中文字幕| 久久久久久久久电影| 青青久久av北条麻妃海外网| 亚洲天堂男人天堂女人天堂| 欧美精品一区二区三区国产精品| 欧美自拍视频在线观看| 欧美激情网站在线观看| 欧美成aaa人片免费看| 欧美亚洲午夜视频在线观看| 国产日韩欧美成人| 亚洲色无码播放| 亚洲国语精品自产拍在线观看| 国产成人福利夜色影视| 国产精品精品久久久| 自拍偷拍免费精品| 国产精品爽黄69天堂a| 亚洲伊人一本大道中文字幕| 自拍偷拍亚洲精品| 91在线高清免费观看| 亚洲精品乱码久久久久久金桔影视| 久久综合伊人77777| 欧美日韩一区二区三区| 国产乱人伦真实精品视频| 国产精品久久中文| 国产精品劲爆视频| 亚洲一区二区久久久| 久久久久久久影视| 亚洲欧美综合图区| 亚洲欧美日本精品| 国产精品亚洲综合天堂夜夜| 欧美福利视频在线| 久久精品国产欧美亚洲人人爽| 亚洲性av在线| 国产精品吊钟奶在线| 亚洲一区二区中文| 8x海外华人永久免费日韩内陆视频| 国产亚洲欧美一区| 亚洲欧洲日产国码av系列天堂| 久久青草福利网站| 久久夜色精品亚洲噜噜国产mv| 欧美激情一区二区三区高清视频| 亚洲国内精品在线| 日韩av影视综合网| 亚洲国产日韩欧美在线99| 91在线免费观看网站| 亚洲一级黄色片| 欧美高清视频免费观看| 欧美电影免费在线观看| 久久久久久国产精品久久| 日韩电影中文字幕| 亚洲性xxxx| 91精品久久久久久久久久久| 日韩美女免费观看| 操91在线视频| 亚洲精品视频网上网址在线观看| 欧美一性一乱一交一视频| 亚洲精品美女在线观看| 亚洲精品中文字幕av| 国产精品久久久久久久久久久新郎| 88xx成人精品| 国产美女搞久久| 国产精品爽爽爽| 精品magnet| 色偷偷综合社区| 亚洲国产精品久久精品怡红院| 国产一区二区三区在线免费观看| 免费97视频在线精品国自产拍| 色婷婷av一区二区三区久久| 久久九九亚洲综合| 欧美成人精品激情在线观看| 国产精品盗摄久久久| 国产精品直播网红| 国产suv精品一区二区三区88区| 神马久久久久久| 精品国模在线视频| 欧美精品在线观看91| 日韩中文字幕第一页| 视频直播国产精品| 在线观看亚洲区| 久久激情视频免费观看| 正在播放欧美一区| 91av在线播放视频| 亚洲精品福利在线观看| 日本91av在线播放| 成人国产精品免费视频| 国产精品一区二区三区久久| 亚洲黄页视频免费观看| 97香蕉超级碰碰久久免费软件| 亚洲视频欧洲视频| 亚洲国产成人精品一区二区| 秋霞av国产精品一区| 91夜夜未满十八勿入爽爽影院| www.久久色.com| 91精品国产综合久久香蕉922| 亚洲自拍另类欧美丝袜| 精品视频偷偷看在线观看| 国产网站欧美日韩免费精品在线观看| 亚洲精品一区在线观看香蕉| 91av在线网站| 亚洲成人av中文字幕| 亚洲综合大片69999| 中文字幕亚洲二区| 欧美日韩国产精品一区二区三区四区| 91精品视频在线播放| 久热国产精品视频| 欧美日韩一区二区三区| 亚洲女人被黑人巨大进入al| 国产亚洲一区二区精品| 亚洲尤物视频网| 中文字幕久精品免费视频| 久久久亚洲影院| 欧美精品videossex88| 欧美专区在线观看| 国产一级揄自揄精品视频| 国产午夜精品久久久| 国产美女精品免费电影| 欧美亚洲另类在线| 欧美视频二区36p| 成人欧美一区二区三区在线| 欧美激情精品久久久| 日韩av综合网站| 亚洲aaaaaa| 国产一区二区视频在线观看| 国产欧美在线播放| 尤物九九久久国产精品的特点| 91精品国产亚洲|