无法从Kendo Combobox获得价值

时间:2018-06-02 12:01:57

标签: kendo-ui kendo-combobox

我在Kendo Grid编辑器中使用以下代码但无法从Combobox访问所选项目值的值。

此外,我在剑道下拉列表中做了同样的事情,但无法使用剑道Combobox,所以如果有人有解决方案,请告诉我。

提前致谢!

{
                    field: "SalesBookId",
                    title: "Sales Book",
                    template: "#= (typeof SalesBookId != 'undefined') ? GetSalesBookName(SalesBookId):'' #",
                    editor: function (container, options) {

                        $('<input required data-text-field="SalesBookName" data-value-field="SalesBookId" data-bind="value:' + options.field + '"/>')
                            .appendTo(container)
                            .kendoComboBox({
                                autoBind: false,
                                dataSource: dsSalesBookDropDown,

                            });
                    }
                },

1 个答案:

答案 0 :(得分:0)

您尚未展示dsSalesBookDropDown,也未展示GetSalesBookName,因此很难知道您的具体情况有什么问题。

这个dojo表明当配置,处理程序和数据都正确对齐时,应该没有问题。

dojo基于“带本地数据的网格”示例,您的 SalesBook 概念更改为卖方示例。

与自定义编辑器相关的代码包括

var sellers = [
  { SellerId: 1, Name: "Andrew" },
  { SellerId: 2, Name: "Basil" },
  { SellerId: 3, Name: "Chuck" },
  { SellerId: 4, Name: "Dennis" },
  { SellerId: 5, Name: "Edward" }
  ];

var dsSellersDropDown = sellers;    

function GetSellerName (id) {
  var seller = sellers.find(function(x) {return x.SellerId == id });
  return (seller) ? seller.Name : "** invalid id " + id + " **";
}

var products = [{
    ProductID : 1,
    ProductName : "Chai",
SellerId: 1,
    SupplierID : 1,
    CategoryID : 1,
. . .

网格配置

                        dataSource: {
                            data: products,
                            schema: {
                                model: {
                                    fields: {
                                        ProductName: { type: "string" },
SellerId: { type: "number" },

                        columns: [
                            "ProductName",
{ field: "SellerId",
  title: "Seller Name",
  template: "#= (typeof SellerId != 'undefined') ? GetSellerName(SellerId):'' #",
  editor: function (container, options) {

    $('<input required data-text-field="Name" data-value-field="SellerId" data-bind="value:' 
+
options.field
+ '"/>')
    .appendTo(container)
    .kendoComboBox({
        autoBind: false,
        dataSource: dsSellersDropDown,
     });
  }
},
                        { field: "UnitPrice", title: "Unit Price", format: "{0:c}", width: "130px" },