最近作項目用了JS模板引擎渲染HTML,JS模板引擎是在去年作項目是瞭解到的,但一直沒有用,只停留在瞭解層面,直到此次作項目纔用到,JS模板引擎用了兩個 BaiduTemplate 和 ArtTemplate。javascript
<script type="text/javascript"> var html; var bt = baidu.template; $(function () { $.ajax({ type: "GET", url: "/Json/Analysis.js", dataType: 'json', success: function (data) { html = bt('t:Jtlm_Analysis', { list: data }); document.getElementById('Jtlm_Analysis').innerHTML = html; } }); }); </script>
模板定製html
<script id="t:Jtlm_Analysis" type="text/html"> <% for(var i=0;i< list.length;i++){%> <div class="widget-box transparent collapsed"> <div class="widget-header widget-header-flat"> <h6 class="orange"> <a href="/d/d/<%=list[i].Id%>" alt="<%=list[i].Title%>" title="<%=list[i].Title%>" target="_blank"><%=list[i].Title%></a> </h6> <div class="widget-toolbar"> <a href="#" data-action="collapse"> <i class="icon-chevron-up"></i> </a> <a href="#" data-action="close"> <i class="icon-remove"></i> </a> </div> <div class="widget-toolbar"> <a> 發佈時間:<%=list[i].UpdateOn%> </a> </div> </div> <div class="widget-body"> <div style="display: block;"> <div class="widget-main"> <p class="alert alert-success"> <%=list[i].Summary%>【<a href="/d/d/<%=list[i].Id%>" target="_blank">詳情</a>】 </p> </div> </div> </div> </div> <%}%> </script>
渲染結果java
ArtTemplate 代碼引入git
$.ajax({ type: "GET", url: "Json/HomeJsonFirst.js?r=" + Math.random(), dataType: 'json', success: function (data) { //Tab 切換 html = template('t:layout_2', { list: data.Layout_2 }); document.getElementById('layout_2').innerHTML = html; //看點 html = template('t:layout_6', { title: JLConsts.Group_Layout_6_Name, list: data.Layout_6 }); document.getElementById('layout_6').innerHTML = html; //開心一刻 html = template('t:layout_7', { title: JLConsts.Group_Layout_7_Name, list: data.Layout_7 });
ArtTemplate 模板github
<script id="t:layout_8" type="text/html"> <h4>{{title}}<i></i></h4> {{each list as value i}} <dl class="cf"> {{each value.HList as a i}} <dd> <a title="{{a.Title}}" alt="{{a.Title}}" target="_blank" href="/Detail/d/{{a.Id}}"> <img src="{{a.ImgSrc}}" title="{{a.Title}}" alt="{{a.Title}}" /> </a> </dd> <dt> <a target="_blank" href="/Detail/d/{{a.Id}}" title="{{a.Title}}" alt="{{a.Title}}">{{a.Title}}</a> </dt> {{/each}} </dl> <ul> {{each value.List as l i}} <li> {{each l.List as a i}} <a title="{{a.Title}}" alt="{{a.Title}}" target="_blank" href="/Detail/d/{{a.Id}}">{{a.Title}}</a> {{/each}} </li> {{/each}} </ul> {{/each}} </script>
渲染結果ajax
基本遍歷模板json
多層遍歷模板dom
簡單的 if else性能
Json構造結果學習