knockout.js使删除按钮工作在一个

时间:2017-04-06 12:21:29

标签: javascript asp.net-mvc knockout.js

这是我的代码

 <div data-bind="with: SimpleListModel">
<form data-bind="submit: addItem" >
    New item:
    <input data-bind='value: itemToAdd, valueUpdate: "afterkeydown"' />
    <button type="submit" data-bind="enable: itemToAdd().length > 0">Add</button>
    <p>Your items:</p>
    <select multiple="multiple" width="50" data-bind="options: items"> </select>
</form>
</div>


<div data-bind="with: SimpleListModel2">
    <ul data-bind="foreach: cardlists">
           <li>
               <span data-bind="text: $data"></span>
               <a href="#" data-bind="click: $root.removecard">Del</a>
           </li>
    </ul>
</div>

这是viewmodel

  var SimpleListModel = function(items) {
    this.items = ko.observableArray(items);
    this.itemToAdd = ko.observable("");
    this.addItem = function() {
        if (this.itemToAdd() != "") {
            this.items.push(this.itemToAdd()); // Adds the item. Writing to the "items" observableArray causes any associated UI to update.
            this.itemToAdd(""); // Clears the text box, because it's bound to the "itemToAdd" observable
        }
    }.bind(this);  // Ensure that "this" is always this view model
};


var SimpleListModel2 = function(cardlists) {
    var self = this;
    self.cardlists= ko.observableArray(cardlists);
    self.removecard = function (cardlist) {
                self.cardlists.remove(cardlist);
     };
};

var masterVM = (function () {
         var self = this;      
         self.SimpleListModel= new SimpleListModel(["Alpha", "Beta", "Gamma"]);
         self.SimpleListModel2= new SimpleListModel2([ "Tall Hat", "LongCloak"]);

})();
ko.applyBindings(masterVM);  

这是我项目中的副本。当我有第二个视图模型时,删除按钮停止工作。 $ root.removecard未定义。如何在这个场景中使用一个mainviewmodel来获取我的$ root.removecard。

1 个答案:

答案 0 :(得分:1)

当您使用$root.removecard更改$parent.removecard时,它会有效。

  var SimpleListModel = function(items) {
    this.items = ko.observableArray(items);
    this.itemToAdd = ko.observable("");
    this.addItem = function() {
        if (this.itemToAdd() != "") {
            this.items.push(this.itemToAdd()); // Adds the item. Writing to the "items" observableArray causes any associated UI to update.
            this.itemToAdd(""); // Clears the text box, because it's bound to the "itemToAdd" observable
        }
    }.bind(this);  // Ensure that "this" is always this view model
};


var SimpleListModel2 = function(cardlists) {
    var self = this;
    self.cardlists= ko.observableArray(cardlists);
    self.removecard = function (cardlist) {
                self.cardlists.remove(cardlist);
     };
};

var masterVM = (function () {
         var self = this;      
         self.SimpleListModel= new SimpleListModel(["Alpha", "Beta", "Gamma"]);
         self.SimpleListModel2= new SimpleListModel2([ "Tall Hat", "LongCloak"]);
      
})();
ko.applyBindings(masterVM);  
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.2.0/knockout-min.js"></script>

 <div data-bind="with: SimpleListModel">
<form data-bind="submit: addItem" >
    New item:
    <input data-bind='value: itemToAdd, valueUpdate: "afterkeydown"' />
    <button type="submit" data-bind="enable: itemToAdd().length > 0">Add</button>
    <p>Your items:</p>
    <select multiple="multiple" width="50" data-bind="options: items"> </select>
</form>
</div>

<div data-bind="with: SimpleListModel2">
    <ul data-bind="foreach: cardlists">
           <li>
               <span data-bind="text: $data"></span>
               <a href="#" data-bind="click: $parent.removecard">Del</a>
           </li>
    </ul>
</div>