我有相同的复选框和单选按钮的数据结构。当检查复选框时,它们会返回正确的布尔值('selected'变量)。KnockoutJS单选按钮不会像复选框一样变化
但是,当我检查单选按钮时,'选择'总是更改为'值'(整数)。
而且单选按钮没有得到 “选中” 在开始的时候,即使 '选择' ==真
的Javascript:
function attributeValueViewModel(data) {
var self = this;
self.id = ko.observable(data.id);
self.attributeID = ko.observable(data.attributeID);
self.value = ko.observable(data.value);
self.chosen = ko.observable(data.chosen);
}
function viewModel() {
var self = this;
self.attributeValues1 = ko.observableArray([]);
self.attributeValues2 = ko.observableArray([]);
self.addToList = function(data) {
ko.utils.arrayForEach(data, function(item) {
self.attributeValues1.push(new attributeValueViewModel(item));
self.attributeValues2.push(new attributeValueViewModel(item));
});
};
}
var arr = [
{
"id": 55,
"attributeID": 28,
"value": "Yes",
"chosen": false,
},
{
"id": 56,
"attributeID": 28,
"value": "No",
"chosen": true,
},
{
"id": 62,
"attributeID": 28,
"value": "Maybe",
"chosen": false,
}
];
var vm = new viewModel();
ko.applyBindings(vm);
vm.addToList(arr);
HTML
<b>Checkbox:</b>
<div id="test1">
<span data-bind="foreach: attributeValues1()">
<input type="checkbox" data-bind="value: id(), checked: chosen, attr: { name: 'test1' }" />
<span data-bind="text: value()"></span>
<span data-bind="text: chosen()"></span>
</span>
</div>
<br />
<b>Radio:</b>
<div id="test2">
<span data-bind="foreach: attributeValues2()">
<input type="radio" data-bind="value: id(), checked: chosen, attr: { name: 'test2' }" />
<span data-bind="text: value()"></span>
<span data-bind="text: chosen()"></span>
</span>
</div>
这是我的小提琴:http://jsfiddle.net/SN7Vn/1/
你能解释这种行为,为什么单选按钮不更新布尔(就像复选框一样)?
谢谢您的回答。我想要的就是“选择”是否为“复选框”,是正确/错误 - 就像复选框一样。另外,如果我添加了一个下拉列表,我希望该值是true/false,无论该值是否在列表中被选中。这可能吗? – Gaui
有可能获得该行为,但需要一些工作。 –
我有一个可能的解决方案来做你想做的事情,但由于应用绑定的未知顺序以及'checked'绑定的工作方式,它似乎非常脆弱。因为这个,我有点犹豫分享这个。 –