使用art-template模板引擎渲染數(shù)據(jù)

一:什么是art-template

  • art-template 是一個(gè)簡(jiǎn)約柴墩、超快的模板引擎。它采用作用域預(yù)聲明的技術(shù)來(lái)優(yōu)化模板渲染速度豫喧,從而獲得接近 JavaScript 極限的運(yùn)行性能靴跛,并且同時(shí)支持 NodeJS 和瀏覽器。使用art-template也便于維護(hù)代碼羞延,以前我們渲染數(shù)據(jù)是以模板字符串的形式在js文件中寫入的html內(nèi)容恤浪,如果html內(nèi)容需要修改,我們需要在js中修改肴楷。而用了模板引擎以后水由,我們只需要html文件中修改html內(nèi)容。還有使用了模板引擎以后DOM操作的效率也會(huì)更高一點(diǎn)赛蔫。

二:art-template特性

  1. 擁有接近 JavaScript 渲染極限的的性能
  2. 調(diào)試友好:語(yǔ)法砂客、運(yùn)行時(shí)錯(cuò)誤日志精確到模板所在行;支持在模板文件上打斷點(diǎn)(Webpack Loader)
  3. 支持 Express呵恢、Koa鞠值、Webpack
  4. 支持模板繼承與子模板
  5. 瀏覽器版本僅 6KB 大小

三:art-template與其他模板引擎運(yùn)行速度對(duì)比

模板引擎運(yùn)行速度對(duì)比

四:關(guān)于art-template的一些學(xué)習(xí)網(wǎng)站

https://github.com/aui/art-template(art-template完整文檔)

https://aui.github.io/art-template/zh-cn/index.html(art-template中文文檔)

五:安裝art-template,有以下2種方式:

  1. 在命令行中使用如下命令
npm install art-template --save
  1. 也可以在瀏覽器中實(shí)時(shí)編譯渗钉,進(jìn)入鏈接ctrl+s保存文件至項(xiàng)目目錄中:lib/template-web.js(gzip: 6kb這個(gè)源碼是壓縮過的)

六:art-template語(yǔ)法

  • art-template 支持標(biāo)準(zhǔn)語(yǔ)法與原始語(yǔ)法彤恶。標(biāo)準(zhǔn)語(yǔ)法可以讓模板易讀寫,而原始語(yǔ)法擁有強(qiáng)大的邏輯表達(dá)能力鳄橘。(例如再使用循環(huán)時(shí)声离,標(biāo)準(zhǔn)語(yǔ)法只能使用each循環(huán)遍歷,而原始語(yǔ)法還可以使用for瘫怜,while等循環(huán))
  • 標(biāo)準(zhǔn)語(yǔ)法支持基本模板語(yǔ)法以及基本 JavaScript 表達(dá)式术徊;原始語(yǔ)法支持任意 JavaScript 語(yǔ)句,這和 EJS 一樣鲸湃。
標(biāo)準(zhǔn)語(yǔ)法
{{value}}
{{data.key}}
{{data['key']}}
{{a ? b : c}}
{{a || b}}
{{a + b}}
原始語(yǔ)法
<% 語(yǔ)句 %>
<% for(var i=0;i<list.length;i++)%{> <%}>
<%=  表達(dá)式 %>
<%= value %>
<%= data.key %>
<%= data['key'] %>
<%= a ? b : c %>
<%= a || b %>
<%= a + b %>

<% %><%= %>這個(gè)的區(qū)別需要注意<% %>這個(gè)跟語(yǔ)句赠涮,若要跟表達(dá)式,則使用<%= %>

七: 定義模板

  • 因?yàn)闉g覽器不支持文件系統(tǒng)暗挑,所以 template(filename, data)不支持傳入文件路徑笋除,它內(nèi)部使用 document.getElementById(filename).innerHTML 來(lái)獲取模板,我們則使用<script id="tpl-user" type="text/html"></script>定義模板炸裆,如下所示:
<script id="tpl-user" type="text/html">
{{if user}}
  <h2>{{user.name}}</h2>
{{/if}}
</script>

八:art-template使用示例:

兩種定義模板方式用一個(gè)就可以了
<div class="span_2 list_box">
    
</div>

    <!-- 定義模板:原始語(yǔ)法 --><!---下面的list為js文件中渲染數(shù)據(jù)對(duì)象的屬性名垃它,curr為遍歷數(shù)組元素對(duì)象時(shí)當(dāng)前屬性值,i為當(dāng)前索引-->
    <script type="text/html" id="list_temp2">
    <% for (var i = 0, len = list.length; i < len; i++) { var curr=list[i]; %>
    <div class="col_1_of_single1 span_1_of_single1">
            <a href="/html/single.html">
             <img src="<%= curr.img_url %>" class="img-responsive" alt=""/>
             <h3><%= curr.title %></h3>
             <p><%= curr.desc %></p>
             <h4><%= curr.price %></h4>
             </a>  
        </div> 
        <% } %>
    </script>
    <!-- 定義模板:標(biāo)準(zhǔn)語(yǔ)法(簡(jiǎn)潔語(yǔ)法) -->
    <script type="text/html" id="list_temp">
    <!--這個(gè)list是js渲染數(shù)據(jù)對(duì)象的屬性名,curr是遍歷數(shù)組元素時(shí)用于代替list的嗤瞎,index是索引墙歪,即curr【index】為當(dāng)前值代替list-->
    {{ each list curr index }}
    <div class="col_1_of_single1 span_1_of_single1">
            <a href="/html/single.html">
             <img src="{{ curr.img_url2 }}" class="img-responsive" alt=""/>
             <h3>{{ curr.title }}</h3>
             <p>{{ curr.desc }}</p>
             <h4>{{ curr.price }}</h4>
             </a>  
        </div> 
        {{ /each }}
    </script>

<!--js文件中使用requirejs引入需要的模塊包括art-template模塊(取的名字為template,這個(gè)模塊是在config文件中配置好的一個(gè)art-template短名稱)贝奇,rap2模擬假數(shù)據(jù)虹菲,jquery獲取假數(shù)據(jù)以及將數(shù)據(jù)渲染至html文件中的.list_box中-->
require(["config"], function(){
  require(["jquery", "template", "header", "footer"], function($, template, header){
    <!--jquery中方法動(dòng)態(tài)獲取列表頁(yè)面數(shù)據(jù)(模擬假數(shù)據(jù))-->
        $.getJSON("http://rap2api.taobao.org/app/mock/25320/api/list", function(data){
    <!--這個(gè)template是art-templatede中有的函數(shù),他有2個(gè)參數(shù)掉瞳,第一個(gè)是script標(biāo)簽的id毕源,第二個(gè)參數(shù)是模板中需要循環(huán)遍歷的對(duì)象和其值-->
            const html = template("list_temp2", {list : data.res_body.data});
            $(".list_box").html(html);
        })
    });
});
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市陕习,隨后出現(xiàn)的幾起案子霎褐,更是在濱河造成了極大的恐慌,老刑警劉巖该镣,帶你破解...
    沈念sama閱讀 207,113評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件冻璃,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡损合,警方通過查閱死者的電腦和手機(jī)省艳,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)嫁审,“玉大人跋炕,你說(shuō)我怎么就攤上這事÷墒剩” “怎么了辐烂?”我有些...
    開封第一講書人閱讀 153,340評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)捂贿。 經(jīng)常有香客問我纠修,道長(zhǎng),這世上最難降的妖魔是什么眷蜓? 我笑而不...
    開封第一講書人閱讀 55,449評(píng)論 1 279
  • 正文 為了忘掉前任分瘾,我火速辦了婚禮,結(jié)果婚禮上吁系,老公的妹妹穿的比我還像新娘。我一直安慰自己白魂,他們只是感情好汽纤,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評(píng)論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著福荸,像睡著了一般蕴坪。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,166評(píng)論 1 284
  • 那天背传,我揣著相機(jī)與錄音呆瞻,去河邊找鬼。 笑死径玖,一個(gè)胖子當(dāng)著我的面吹牛痴脾,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播梳星,決...
    沈念sama閱讀 38,442評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼赞赖,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了冤灾?” 一聲冷哼從身側(cè)響起前域,我...
    開封第一講書人閱讀 37,105評(píng)論 0 261
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎韵吨,沒想到半個(gè)月后匿垄,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,601評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡归粉,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評(píng)論 2 325
  • 正文 我和宋清朗相戀三年年堆,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片盏浇。...
    茶點(diǎn)故事閱讀 38,161評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡变丧,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出绢掰,到底是詐尸還是另有隱情痒蓬,我是刑警寧澤,帶...
    沈念sama閱讀 33,792評(píng)論 4 323
  • 正文 年R本政府宣布滴劲,位于F島的核電站攻晒,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏班挖。R本人自食惡果不足惜鲁捏,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望萧芙。 院中可真熱鬧给梅,春花似錦、人聲如沸双揪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)渔期。三九已至运吓,卻和暖如春渴邦,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背拘哨。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工谋梭, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人倦青。 一個(gè)月前我還...
    沈念sama閱讀 45,618評(píng)論 2 355
  • 正文 我出身青樓瓮床,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親姨夹。 傳聞我的和親對(duì)象是個(gè)殘疾皇子纤垂,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評(píng)論 2 344