使用 Durandal JS 框架和 Kendo UI。
在我的网格中,我希望portfolioName 和m InstrumentName 都显示文本字段,但是当我点击下面的SAVE 事件时,我想拉出ID 字段。
我现在遇到的问题是,当我进入 INSERT 模式并从工具/投资组合下拉列表中进行选择时,它会使用 ID 填充网格;但是我希望 TEXT 显示。例如, InstrumentId 与 InstrumentName。
我在 ViewModel 代码中使用一些 DropDown 编辑器定义了一个网格,如下所示:
positGrid = $("#positGrid").kendoGrid({
dataSource: datasource,
columnMenu: false,
toolbar: [
{ name: "create", text: "Add" }
],
columns: [{
field: "id", hidden: true,
},
{
field: "portfolioName", title: "Portfolio Name",
editor: portfolioDropDownEditor, template: "#=portfolioName.name#"
},
{
field: "InstrumentName",
width: "220px",
editor: instrumentsDropDownEditor, template: "#=InstrumentName#",
},
save: function (e) { // inline row save event
InsertUpdatePos(e)
},
});
这是下拉编辑器功能:
// PULL PORTFOLIO LISTING FROM SERVER AND DISPLAY IN DROPDOWN LIST
function portfolioDropDownEditor(container, options) {
var pfItems = [{ // FOR TESTING ONLY...
"pfName": "1"
}, {
"pfName": "2"
}];
//var input = $('<input id="portfolioName" name="portfolioName">');
var input = $('<input required id="portfolioName" data-text-field="name" data-value-field="id"> data-bind="value:' + options.field + '" ');
input.appendTo(container);
// debugger;
input.kendoDropDownList({
dataTextField: "name",
dataValueField: "id",
dataSource: {
type: "json",
transport: {
read: "/api/breeze/GetPortfolios"
},
pageSize: 6,
},
optionLabel: "Choose a portfolio",
}).appendTo(container);
}
我使用这个剑道示例作为指南,但仍然无法让它工作:http ://demos.kendoui.com/web/grid/editing-custom.html
谢谢。鲍勃