0

我有一个 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中看到已编辑的值,但我还没有弄清楚如何绑定到它。

我在这里创建了一个 plunk 来帮助说明:https ://plnkr.co/edit/Ibc0WZwyb4melgNDzcUo

谁能告诉我需要如何设置我的 emailCellTemplate?

4

1 回答 1

0

感谢您的评论,我现在已经找到了该错误的原因。

问题出在我的 javascript 控制器的savetoDatabase函数中。控制器确实定义了一个可观察对象this.workflowRules = ko.observableArray(vm.WorkflowRules);,但在saveToDatabase函数中,它在调用服务器控制器之前转换为 JSON 时使用了服务器视图模型var jsSaveModel = ko.toJS(vm);

为了解决这个问题,我添加了一个额外的行,在转换为 JSON 之前使用 observable 的内容更新 vm 的WorkflowRules数组,所以我现在有了

vm.WorkflowRules = this.workflowRules();
var jsSaveModel = ko.toJS(vm);
于 2016-03-30T08:38:40.127 回答