knockoutjs - 在foreach绑定中访问$ parent / $ root

时间:2016-11-08 11:32:36

标签: knockout.js knockout-2.0 knockout-3.0

Here是我正在处理的一个插件代码。我已经定义了一个看起来像这样的VM。

    var employee = function(fname,lname){
    var self= this;
    self.fname = ko.observable(fname);
    self.lname = ko.observable(lname);
    self.selectedElement = ko.observable('Default Value');
  }

  var vm = function(){
      var self = this;
      self.employees = new ko.observableArray([]);
      self.selectedElement = ko.observable(-1);

      var e1 = new employee('f1','l1');
      var e2 = new employee('f2','l2');
      self.employees.push(e1);
      self.employees.push(e2);
  };

  ko.applyBindings(vm,container);

我显示员工名单的代码是

<body id="container">
<h1>Empoyees</h1>
<div>
  <div data-bind="foreach: employees">
    <h4 data-bind="text: 'Employee' + $index()"></h4>
    <span>First Name :</span>
    <span data-bind="text: fname"></span>
    <br/>

    <span>Last Name :</span>
    <span data-bind="text: fname"></span>
    <br/>

    <span data-bind="text: selectedElement()"></span>
    <!-- I want to access parents 'selectedElement' i.e. vm.slectedElement() -->
    <!--I tried below code but its causing binding error.-->
    <!-- <span data-bind="text: $parent.selectedElement()"></span> -->
    <br/>
  </div>
</div>

请注意,“employee”和主视图模型“vm”都具有相同的属性(selectedElement

现在在foreach绑定中,我试图访问root / parent上下文的'selectedElement'属性,但因为我在foreach ko内部正在访问'employee'类的'selectedElement'属性。

我尝试使用$root$parent关键字来访问父元素属性,但却导致绑定错误。

我错过了什么吗? Here再次成为了吸引人的链接。

1 个答案:

答案 0 :(得分:3)

您永远不会创建根视图模型的实例。将初始调用更改为

ko.applyBindings(new vm(),container);

https://plnkr.co/edit/wRKfnJi9Jl9Rj2unbgQp?p=preview

执行此操作时,$root$parent将按预期工作。