我对 knockoutjs 比较陌生,但我似乎遇到了一个 observableArray 复选框的问题,这些复选框有一些可观察的属性,用于检查和禁用。
使用敲除我可以选中和取消选中该框,但似乎一旦我手动与复选框交互(即通过鼠标单击它),基础数据似乎正在发生变化,但我不能使用敲除来选中或取消选中该框了。
HTML
<div id="filterByPrice" data-bind="foreach: priceFilters">
<div>
<input type="checkbox" data-bind="attr: {id: $index, value: value, checked: checked, disable: disabled}" />
<span data-bind="text: label"></span>
</div>
</div>
Javascript
function FilterBy(name, value, label) {
this.name = name;
this.value = value;
this.label = label;
this.disabled = ko.observable(false);
this.checked = ko.observable(false);
}
$(function () {
var viewModel = {
priceFilters: ko.observableArray([
new FilterBy("price0", "0", "All Prices")])
};
ko.applyBindings(viewModel);
});
http://jsfiddle.net/paulwilliams0/EYEz2/
我在做什么是错的吗?我不仅是淘汰赛的新手,而且我对 MVVM 也很陌生。非常感谢