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

首頁(yè) > 語(yǔ)言 > JavaScript > 正文

JavaScript模板引擎原理與用法詳解

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

本文實(shí)例講述了JavaScript模板引擎原理與用法。分享給大家供大家參考,具體如下:

一、前言

什么是模板引擎,說的簡(jiǎn)單點(diǎn),就是一個(gè)字符串中有幾個(gè)變量待定。比如:

var tpl = 'Hei, my name is <%name%>, and I/'m <%age%> years old.';

通過模板引擎函數(shù)把數(shù)據(jù)塞進(jìn)去,

var data = {  "name": "Barret Lee",  "age": "20"};var result = tplEngine(tpl, data);//Hei, my name is Barret Lee, and I'm 20 years old.

那這玩意兒有什么作用呢?其實(shí)他就是一個(gè)預(yù)處理器(preprocessor),搞php開發(fā)的童鞋對(duì)Smarty必然是十分熟悉,Smarty是一個(gè)php模板引擎,tpl中待處理的字符通過數(shù)據(jù)匹配然后輸出相應(yīng)的html代碼,加之比較給力的緩存技術(shù),其速度和易用性是非常給力的!JS Template也是一樣的,我們的數(shù)據(jù)庫(kù)里保存著數(shù)以千萬(wàn)計(jì)的數(shù)據(jù),而每一條數(shù)據(jù)都是通過同一種方式輸入,就拿上面的例子來說,我們不可能在數(shù)據(jù)庫(kù)里存幾千條"Hei, my name...",而是只保存對(duì)應(yīng)的name和age,通過模板輸出結(jié)果。

JS模板引擎應(yīng)該做哪些事情?看看下面一串代碼:

var tpl = '<% for(var i = 0; i < this.posts.length; i++) {' +   'var post = posts[i]; %>' +  '<% if(!post.expert){ %>' +    '<span>post is null</span>' +  '<% } else { %>' +    '<a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><% post.expert %> at <% post.time %></a>' +  '<% } %>' +'<% } %>';

一個(gè)基本的模板引擎至少可以保證上面的代碼可以正常解析。如送入的數(shù)據(jù)是:

var data = {  "posts": [{    "expert": "content 1",    "time": "yesterday"  },{    "expert": "content 2",    "time": "today"  },{    "expert": "content 3",    "time": "tomorrow"  },{    "expert": "",    "time": "eee"  }]};

可以輸出:

<a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >content 1 at yesterday</a><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >content 2 at today</a><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >content 3 at tomorrow</a><span>post is null</span>            
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 甘洛县| 射洪县| 浑源县| 莱州市| 红安县| 琼中| 东阿县| 西乌珠穆沁旗| 平塘县| 什邡市| 屯门区| 隆林| 通渭县| 江西省| 东至县| 三明市| 丰镇市| 稷山县| 施秉县| 镇远县| 柳河县| 周宁县| 广饶县| 青铜峡市| 潮安县| 治多县| 师宗县| 安平县| 开封县| 广州市| 南川市| 保山市| 慈利县| 徐闻县| 元氏县| 达孜县| 吉隆县| 澎湖县| 彰武县| 古交市| 呼伦贝尔市|