我是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条记录,当用户点击“再添加一条”时,没有记录被添加到视图模型中,也没有反映在视图中。
JSFiddle链接:http://jsfiddle.net/Rama_Kishore/AGycj/
感谢您的帮助。