0

我有以下标记:

<ul data-bind="foreach: nameList">
    <li data-bind="text: $data"></li>
</ul>
<button data-bind="click: addname">add name</button>
Total names: <span data-bind="text: nameList().length"></span>

我的视图模型如下所示:

var viewmodel = {
    nameList: ko.observableArray(["Brian"]),
    number: ko.observable(100),
    addname: function(){
        alert(this.nameList().length);
        this.nameList().push("name");
        alert(this.nameList().length);
    }
};

ko.applyBindings(viewmodel);

每当执行 addname 方法时,alert 都会更新 nameList 数组,但标记不会反映这些更改。那么它有什么问题呢?

4

1 回答 1

2

知道了!你需要改变:

this.nameList().push("name");

对此:

this.nameList.push("name");

(因为nameList是数组,不是方法)

演示:http: //jsfiddle.net/G464V/

于 2013-03-28T18:56:16.783 回答