我在显示从组合框到淘汰赛列表的值时遇到一个问题。请在下面的图片中我从组合框中选择项目。当我从组合框中选择项目时,它会更新所有具有相同值的行。
左侧的列表不存储数据库中组合框中的名称,但它存储 id。所以组合框和列表与称为状态的列相连。在我的 html 中,我定义了如下列表,其中 ChangeControlName 是我要绑定到列表的列表
<tbody data-bind="foreach: versionDataByProduct">
<tr data-bind="click: $root.EditVersionDetail, css: { selected: isSelected}" >
<td data-bind="text: Name "></td>
<td data-bind="text: Code"></td>
<td data-bind ="text: PlatformVersionName"></td>
<td data-bind ="text: ChangeControlName"></td>
</tr>
组合框在我的视图模型中加载如下
// Load Change Control List
function loadChangeControlList() {
$.ajax({
url: "../RestService/Product/ChangeControlList",
type: "PUT",
contentType: 'application/json',
processData: false,
error: function (XMLHttpRequest, textStatus, errorThrown) {
},
success: function (allData) {
var mappedChangeControls = $.map(allData, function (item) {
return new changeControlList(item);
});
self.ChangeControls(mappedChangeControls);
}
});
}
我已经在 html 中绑定了我的组合框,如下所示
<td><select id="selModuleType" data-bind="options: $root.modules, optionsCaption: 'Please select Module...' , value: $root.editModuleId , optionsText: 'ModuleName'" /></td>
当我在左手边选择行时,如上图所示,我得到 selectedrow。在值 editModuleId 的订阅事件上,我尝试将值分配给选定的行,如下所示。
self.editChangeControl.subscribe(function (value) {
if (!value) {
return;
}
self.selecteditem().ChangeControlId(value.Status());
self.selecteditem().ChangeControlName(value.ChangeControl());
});
在上面的代码中 selecteditem 包含我们选择的行。正如您在上面的代码中看到的,ChangeControlId 是我们从组合框中选择的值的 id,它已正确设置到列表中。但是名称设置不正确。原因是 ChangeControlId 存储在数据库中。ChangeControlId 是显示这些行的表的一部分。我想要的 ChangeControlName 仅用于显示目的。我应该怎么办?我也尝试使用计算的 observable,但它在列表中显示为“对象对象”。我使用如下计算的 observable
this.ChangeControlName = ko.computed({
read: function () {
debugger;
return ko.utils.arrayFirst(self.ChangeControls(), function (item) {
if (item.Status() === productVersionId.ChangeControlId()) {
return item.ChangeControl();
}
});
},
write: function (value) {
console.log("Value i get " + value);
return value;
}
});