如何使用Knockout模板在Knockout中创建树结构?

时间:2016-09-01 10:41:49

标签: javascript database knockout.js knockout-2.0 knockout-templating

我正在使用Knockout支持,现在正在创建树结构UI组件。在这里,我将动态创建元素,并且我想将数据绑定到新创建的元素。 请查看以下代码

<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.2.0/knockout-min.js"></script>

<script type="text/html" id="tree">
   <li menuid="data bind with attr binding">
      <span>&nbsp;</span>
      <span><a href="#" name="endnode"></span>
      <ul data-bind="template: { name: 'tree', foreach: childNodes }">
     </ul>
   </li>

下面是我的脚本

 var viewModel = {
 Mytree: ko.observable({
childNodes: [
  {
    id: 1,name:"node1",
    childNodes: [ {id: 2, name:"node2", childNodes: [{id: 3,name:"node3", childNodes: [] }] } ]
  },
  {
    id: 4,name:"node4",
    childNodes: [ {id: 5,name:"node5", childNodes: [] } ]
   }
 ]
  })
};

ko.applyBindings(new viewModel.Mytree());

现在我想将bindable节点名称附加到树,如下所示:

<span><a href="#" name="endnode" data-bind:"text:childNodes.name"/></span>

<ul data-bind="template: { name: 'tree', foreach: childNodes }">

你能不能请任何人建议我实现这个目标

1 个答案:

答案 0 :(得分:3)

如果您传递视图模型(您可以使用$ root语法),您只需在绑定中使用“name”即可。上下文会随着它在树下面而改变......还有一些其他的错误 - 一个是数据绑定=(等于,不是冒号)

试试这个模板......

      <script type="text/html" id="tree">
         <li menuid="data bind with attr binding">
            <span>&nbsp;</span>
            <a href="#" data-bind="text: name"></a>
            <ul data-bind="template: { name: 'tree', foreach: childNodes }" />
         </li>
     </script>

并使用它来解决问题(注意$ root)

  <ul data-bind="template: { name: 'tree', data: $root }" />

这会给你......

enter image description here