我目前在学习和使用knockout js框架。我有一组基本的联系人字段。我可以添加没有任何问题的联系人。但我在设置性别male
和female
的值时遇到困难。我已经正确声明,但在阅读JSON对象时,它不显示任何性别值。为什么不显示联系人是男性还是女性? JSFIDDLE从json对象获取复选框值
var initialData = [{
firstName: "Jenny",
lastName: "LaRusso",
phone: "(555) 121-2121",
alt_phone: "(555) 123-4567",
male: false,
female: true
}, {
firstName: "Sensei",
lastName: "Miyagi",
phone: "(555) 444-2222",
alt_phone: "(555) 999-1212",
male: true,
female: false
}];
var ContactsModel = function (contacts) {
var self = this;
self.contacts = ko.observableArray([]);
ko.utils.arrayForEach(contacts, function (contact) {
self.contacts.push({
firstName: contact.firstName,
lastName: contact.lastName,
phone: contact.phone,
alt_phone: contact.alt_phone,
male: contact.male,
female: contact.female
});
});
self.addContact = function() {
self.contacts.push({
firstName: "",
lastName: "",
phone: "",
alt_phone: "",
male: false,
female: false
});
};
self.removeContact = function (contact) {
self.contacts.remove(contact);
};
self.addPhone = function (contact) {
contact.phones.push({
number: ""
});
};
self.removePhone = function (phone) {
$.each(self.contacts(), function() {
this.phones.remove(phone)
})
};
self.save = function() {
self.lastSavedJson(JSON.stringify(ko.toJS(self.contacts), null, 2));
};
self.lastSavedJson = ko.observable("")
};
ko.applyBindings(new ContactsModel(initialData));
我认为性别选择,你应该使用单选按钮不复选框。 通过单选按钮,您还可以收音一个额外的字段。 – Akhlesh