Znalazłem przykład here, aby utworzyć listę wyboru z optgroups przy użyciu KnockoutJS. Działa to dobrze, ale chcę, aby powiązać wartość rozwijanej do mojego JavaScript Object, a następnie uzyskać dostęp do szczególnej właściwości tego obiektu:KnockoutJS - Wiązanie wartości zaznaczenia przy użyciu obiektów optgroup i javascript
<select data-bind="foreach: groups, value:selectedOption">
<optgroup data-bind="attr: {label: label}, foreach: children">
<option data-bind="text: label"></option>
</optgroup>
</select>
function Group(label, children) {
this.label = ko.observable(label);
this.children = ko.observableArray(children);
}
function Option(label, property) {
this.label = ko.observable(label);
this.someOtherProperty = ko.observable(property);
}
var viewModel = {
groups: ko.observableArray([
new Group("Group 1", [
new Option("Option 1", "A"),
new Option("Option 2", "B"),
new Option("Option 3", "C")
]),
new Group("Group 2", [
new Option("Option 4", "D"),
new Option("Option 5", "E"),
new Option("Option 6", "F")
])
]),
selectedOption: ko.observable(),
specialProperty: ko.computed(function(){
this.selectedOption().someOtherProperty();
})
};
ko.applyBindings(viewModel);
Dziękuję bardzo! – user888734
Dzięki za pomoc! Prosty i wydajny. – Mounir
Jak dodać "optionsCaption" do tego rozwiązania? @RP Niemeyer –