使用Durandal JS框架和Kendo UI。
在我的网格中,我希望portfolioName和m InstrumentName都显示文本字段,但是当我点击下面的SAVE事件时,我想拉出ID字段。
我现在遇到的问题是当我进入INSERT模式并从乐器/组合DropDown列表中选择时,它会使用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);
}
我正在使用此kendo示例作为指南,但仍无法使其正常工作:http://demos.kendoui.com/web/grid/editing-custom.html
感谢。 鲍勃