1

使用 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.c​​om/web/grid/editing-custom.html

谢谢。鲍勃

4

0 回答 0