我是 Knockout 的新手,正在尝试在 Knockout 中学习 Click 绑定。
我的示例代码是
HTML
<button data-bind="click: addEmp('fnameX', 'lnameX')">Add one more</button>
<ul data-bind="foreach: employees">
<li>
<span data-bind="text: fname"> </span> <span data-bind="text: lname"> </span>
</li>
</ul>
JavaScript
// model
function employee(fname, lname) {
this.fname = ko.observable(fname);
this.lname = ko.observable(lname);
}
// view model
var vm = {
company: ko.observable('Company Name'),
employees: ko.observableArray(),
addEmp: function (fname, lname) {
this.employees.push(new employee(fname, lname));
}
};
// adding employees to array
vm.addEmp('fname1', 'lname1');
vm.addEmp('fname2', 'lname2');
//binding
ko.applyBindings(vm);
我期待:
应显示 2 条记录,当用户单击“再添加一条”时,应将一条新记录添加到 viewmodel 中,并反映在我的视图中。
但是,实际输出是:
最初显示了 3 条记录,当用户单击“再添加一条”时,没有记录被添加到 viewmodel 中,并且没有反映在视图中。
JSFiddle 链接:http: //jsfiddle.net/Rama_Kishore/AGycj/
感谢你的帮助。