首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >带有doT.js的嵌套列表(来自嵌套数组/对象)

带有doT.js的嵌套列表(来自嵌套数组/对象)
EN

Stack Overflow用户
提问于 2016-01-20 11:31:43
回答 1查看 1.1K关注 0票数 2

有没有一种使用doT.js生成嵌套列表的方法?不幸的是,我的代码只遍历数组中的第一个对象(g1),并忽略了以下所有内容。有办法用doT.js解决这个问题吗?

结果应该是:

代码语言:javascript
复制
G1
 T11
 T12
 T13
G2
 T21
 T22
 T23

代码语言:javascript
复制
$(document).ready(function() {
  var data_simple = {
    level1: [{
      name: 't1'
    }, {
      name: 't2'
    }, {
      name: 't3'
    }]
  };

  var data_complex = {
    level1: [{
      name: 'g1',
      data: [{
        name: 't11'
      }, {
        name: 't12'
      }, {
        name: 't13'
      }]
    }, {
      name: 'g2',
      data: [{
        name: 't21'
      }, {
        name: 't22'
      }, {
        name: 't23'
      }]
    }]
  };

  var compiled_tpl_simple = doT.template($('[data-template="simple"]').html());
  var compiled_tpl_complex = doT.template($('[data-template="complex"]').html());
  
  var result_simple = compiled_tpl_simple(data_simple);
  var result_complex = compiled_tpl_complex(data_complex);

  $('#output_simple').append(result_simple);
  $('#output_complex').append(result_complex);
});
代码语言:javascript
复制
<script src="https://cdnjs.cloudflare.com/ajax/libs/dot/1.0.3/doT.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>

<script data-template="simple" type="text/x-dot-template">
	<strong>Beg simple</strong><br>
	{{~it.level1 :element:index}}
		{{=element.name}}<br>
	{{~}}
  <strong>End simple</strong>
</script>

<script data-template="complex" type="text/x-dot-template">
	<strong>Beg complex</strong><br>
	{{~it.level1 :group:index}}
  	  {{=group.name}}<br>
      {{~group.data :element:index}}
    	{{=element.name}}<br>
      {{~}}
	{{~}}
  <strong>End complex</strong>
</script>

<div id="output_simple">

</div>
<div id="output_complex">

</div>

https://jsfiddle.net/srw2ogpz/

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-11-23 07:42:06

若要解决此问题,请更改嵌套列表中的索引名称。

代码语言:javascript
复制
<script data-template="complex" type="text/x-dot-template">
<strong>Beg complex</strong><br>
{{~it.level1 :group:index}}
   {{=group.name}}<br>
   {{~group.data :element:index2}}
      {{=element.name}}<br>
   {{~}}
{{~}}
<strong>End complex</strong>
</script>
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34898853

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档