我有一个Asp.Net MVC网站,我已经开始使用knockoutjs kogrid来显示数据网格。
对于一个特定的网格,我希望用户能够编辑电子邮件地址列。单击保存按钮时,编辑后的值应保留在数据库中。
我能够显示网格确定,并且在选择行时,用户可以键入所需的单元格。我的问题是,我还没弄清楚如何引用已更改的单元格值。
以下是我的网格选项的定义:
var emailCellTemplate = '<div><input type=\"text\" data-bind=\"visible: $parent.selected(), value: $parent.entity[$data.field]" /><span data-bind=\"visible: !$parent.selected(), text: $parent.entity[$data.field]\"></span></div>'
this.gridOptions = {
height: 200,
afterSelectionChange: function () { return true; },
data: self.workflowRules,
enablePaging: true,
pagingOptions: self.pagingOptions,
filterOptions: self.filterOptions,
selectWithCheckboxOnly: true,
selectedItems: self.selected,
canSelectRows: true,
displaySelectionCheckbox: true,
columnDefs: [{ field: 'ReceivePortName', displayName: 'Receive Port', width: 130 },
{ field: 'MessageType', displayName: 'Message Type', width: 400 },
{ field: 'TriggerSource', displayName: 'Source', width: 150 },
{ field: 'TargetEmailAddress', displayName: 'Email', width: 180, cellTemplate: emailCellTemplate },
{ field: 'AssignedToName', displayName: 'Assigned To', width: 140 },
]
};
$ parent.entity [$ data.field] 非常适合选择从数据库加载的值,但不会给我编辑的值。当我在单击保存到数据库按钮时运行的js代码上放置断点时,我确实可以在 WorkflowRules.TargetEmailAddress 中看到已编辑的值,但我有我没弄明白如何绑定它。
我已经创建了一个插件来帮助说明:https://plnkr.co/edit/Ibc0WZwyb4melgNDzcUo
有人可以告诉我如何设置emailCellTemplate吗?
答案 0 :(得分:0)
感谢您的评论,我现在已经找到了错误的原因。
问题出在我的javascript控制器的 savetoDatabase 函数中。控制器确实定义了一个可观察的this.workflowRules = ko.observableArray(vm.WorkflowRules);
,但在 saveToDatabase 函数中,它在调用服务器控制器var jsSaveModel = ko.toJS(vm);
之前转换为JSON时使用了服务器视图模型
为了解决这个问题,我添加了一行额外的行来更新vm的 WorkflowRules 数组,其中包含observable的内容,然后转换为JSON,所以我现在有了
vm.WorkflowRules = this.workflowRules();
var jsSaveModel = ko.toJS(vm);