Heim >Web-Frontend >HTML-Tutorial >js模版引擎handlebars.js实用教程??循环中使用索引_html/css_WEB-ITnose

js模版引擎handlebars.js实用教程??循环中使用索引_html/css_WEB-ITnose

WBOY
WBOYOriginal
2016-06-24 12:07:131465Durchsuche

 1 <!DOCTYPE html> 2 <html> 3   <head> 4     <META http-equiv=Content-Type content="text/html; charset=utf-8"> 5     <title>关于循环中索引的使用 - by 杨元</title> 6   </head> 7   <body> 8     <h1>关于循环中索引的使</h1> 9     <!--基础html框架-->10     <table>11       <thead>12         <tr>13           <th>序号</th>14           <th>姓名</th>15           <th>性别</th>16           <th>年龄</th>17         </tr>18       </thead>19       <tbody id="tableList">20         21       </tbody>22     </table>23     24     <!--插件引用-->25     <script type="text/javascript" src="script/jquery.js"></script>26     <!--注意!这个例子用的是新版本handlebars,旧版本不支持-->27     <script type="text/javascript" src="script/handlebars-v1.3.0.js"></script>28     29     <!--Handlebars.js模版-->30     <!--Handlebars.js模版放在script标签中,保留了html原有层次结构,模版中要写一些操作语句-->31     <!--id可以用来唯一确定一个模版,type是模版固定的写法-->32     <script id="table-template" type="text/x-handlebars-template">33       {{#each student}}34       <tr>35         <td>{{addOne @index}}</td>36         <td>{{name}}</td>37         <td>{{sex}}</td>38         <td>{{age}}</td>39       </tr>40       {{/each}}41     </script>42     43     <!--进行数据处理、html构造-->44     <script type="text/javascript">45       $(document).ready(function() {46         //模拟的json对象47          var data = {48                       "student": [49                           {50                               "name": "张三",51                               "sex": "0",52                               "age": 1853                           },54                           {55                               "name": "李四",56                               "sex": "0",57                               "age": 2258                           },59                           {60                               "name": "妞妞",61                               "sex": "1",62                               "age": 1963                           }64                       ]65                   };66         67         //注册一个Handlebars模版,通过id找到某一个模版,获取模版的html框架68         //$("#table-template").html()是jquery的语法,不懂的童鞋请恶补。。。69         var myTemplate = Handlebars.compile($("#table-template").html());70         71         //注册一个Handlebars Helper,用来将索引+1,因为默认是从0开始的72         Handlebars.registerHelper("addOne",function(index,options){73           return parseInt(index)+1;74         });75         76         //将json对象用刚刚注册的Handlebars模版封装,得到最终的html,插入到基础table中。77         $('#tableList').html(myTemplate(data));78       });79     </script>80   </body>81 </html>

 

 

     序号是指:在循环过程中,当前循环的索引,说白了,就是当前为第几次循环,一般从0开始,Handlebars.js中也是如此。

     有什么用呢?最常见的是在显示table的时候,给每行加一个序号,清晰的展示出页面上共有多少条记录,如上边的例子。

     除此之外,小菜为了在循环中区分不同的id,恰好需要一个序号,确保id不重复,用过bootstrap的童鞋应该知道,好多事件可以通过id定位,例如Listgroup控件。

     废话少说,在Handlebars.js中,可以通过{{@index}}来获取当前的索引,也就是说@index这个变量就代表了当前索引。

     在上边的例子里,table的序号从0开始不太好,于是注册了一个Helper,将索引+1。

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn