0

我有一个案例,我的 ViewModel 有一个数组,例如,

{id: 0,
 Name: "KendoListView1",
 dataitems: [{id: 1, itemName: "Kendo"}, {id: 2, itemName: "List"}]
},

{id: 2,
 Name: "KendoListView2",
 dataitems: [{id: 3, itemName: "Kendo"}, {id: 4, itemName: "List"}]
}, 

{id: 3,
 Name: "KendoListView3",
 dataitems: []
}

所以现在当我将我的 ViewModel 绑定到 ListView 模板时,我的模板需要处理这样的情况,如果有一个数组,我会在视图中显示数组元素,而当数组为空时,我只需要显示名称(KendoListView1 , KendoListView2) 而不是 Array 元素

我需要这样的模板结构:

<script id="template" type="text/kendo-ui-template">  
# if(dataitems.length) { #
    <div>
         //Show all the items Names from the Array
    </div>
# } else {#
    <div>
         //Show all the Names
    </div>
# } #
</script>

我尝试使用 for 循环遍历 Array 并在我有 Array 时显示项目,但在运行时,一旦我将新项目添加到 Array 中,for 循环将再次运行所有项目并显示所有项目。

在这种情况下谁能帮助我

4

1 回答 1

0

A.Map().Join()可用于渲染有时填充的dataitems.

模板

  <script id="my_funky_listview_template" type="text/x-kendo-template">
    <div>
    # if (dataitems.length) { #
      #:
        itemName + " items: " + dataitems.map(function(item){return item.itemName;}).join(",")
      #
    # } else { #
      #:
        Name
      #
    # } #
    </div>
  </script>

声明/配置

<script>
$(function() {
  $("#listview").kendoListView({
    dataSource: dataSource,
    template: kendo.template($("#my_funky_listview_template").html())
  });     
});
</script>

如果数据源提供任何缺少Namedataitems属性的内容,javascript 控制台将记录一条'<property>' is not defined.消息并且列表视图不会出现。

于 2017-12-13T19:44:44.060 回答