我已经查看了其他问题,但无法让我的选择框正常工作: Binding initial/default value of dropdown (select) list
我有以下Game对象:
function Game(visitingTeamDetails, homeTeamDetails, game) {
if (arguments.length > 0) {
this.VisitingTeamDetails = visitingTeamDetails;
this.HomeTeamDetails = homeTeamDetails;
this.GameId = ko.observable(game.GameId);
this.HomeTeamName = ko.observable(game.HomeTeamName);
this.VisitingTeamName = ko.observable(game.VisitingTeamName);
this.SportTypeName = ko.observable(game.SportTypeName);
this.HomeAccountName = ko.observable(game.HomeAccountName);
this.VisitingAccountName = ko.observable(game.VisitingAccountName);
this.GameDateString = ko.observable(game.GameDateString);
this.GameTimeString = ko.observable(game.GameTimeString);
this.AvailableSportTypes = ko.observableArray(game.Sports);
this.sportTypeFunction = function () {
for (sportType in this.AvailableSportTypes()) {
if (this.AvailableSportTypes()[sportType].Name == this.SportTypeName()) {
return this.AvailableSportTypes()[sportType];
}
}
return null;
};
this.SportType = ko.observable(game.SportType);
}
}
SportType是Name
和SportTypeId
的对象。
我有以下模板:
<td rowspan="3"><select data-bind="options: AvailableSportTypes, value: SportType, optionsText:'Name', optionsCaption: 'Choose...'" class="sportType"></select></td>
AvailableSportTypes
是SportType
。
列表中的下载列表中列出了SportTypes的名称,但我无法将初始选择设为SportType
。我写了sportTypeFunction
来向我自己说明数据输入正确,它会选择正确的值,但在下拉列表中更改我的选择不会更新SportType。
我确定我做错了什么。有人看到了吗?
由于
答案 0 :(得分:11)
传递game.SportType
时,它需要是对game.AvailableSportTypes
中某个项目的引用,而不仅仅是一个看起来相同的对象。
基本上两个对象不相等,除非它们实际上是对同一对象的引用。
var a = { name: "test" },
b = { name: "test" };
alert(a === b); //false
因此,您需要调用函数来定位数组中的正确对象,并将其设置为您的observable的值。
并不是说它更好,但在KO 1.3中,您可以扩展.fn
的observables,observableArrays和dependentObservables来添加其他功能。