我希望通过在Javascript中定义的数组循环并渲染一组单选按钮。我的代码目前无法工作,如下所示(也可以在jsfiddle上查看):
<div data-bind="foreach: options" >
<div>
<input type="radio" name="optionsGroup" data-bind="checked: selected" />
<span data-bind="text: label"></span>
</div>
</div>
var optionsList = [
{"value": "a","label": "apple"},
{"value": "b","label": "banana"},
{"value": "c","label": "carrot"}
];
function viewModel() {
var self = this;
self.options = optionsList;
self.selected = ko.observable("a");
self.selected.subscribe(function(newValue) {
alert("new value is " + newValue);
});
}
ko.applyBindings(new viewModel());
如果我的数组是HTML的一部分,那么它可以正常工作,可以参考这个(或jsfiddle):
<div>
<input type="radio" name="optionsGroup" value="a" data-bind="checked: selected" />Apple
</div>
<div>
<input type="radio" name="optionsGroup" value="b" data-bind="checked: selected" />Banana
</div>
<div>
<input type="radio" name="optionsGroup" value="c" data-bind="checked: selected" />Carrot
</div>
<div data-bind="text: selected">
</div>
function viewModel() {
var self = this;
self.selected = ko.observable("a");
self.selected.subscribe(function(newValue) {
alert("new value is " + newValue);
});
}
ko.applyBindings(new viewModel());
我通过在JavaScript中生成所有HTML并使用复选框使其正常工作,但是在使用foreach迭代器生成一组单选按钮时遇到了难题。
有人能否提供像我第一个例子一样的示例?
var self = this
。 删除该行并将所有的self
更改为this
。作用域没有问题。 - ruffin