如何在“编辑”事件上将Kendo.Combobox绑定到其数据源?

时间:2019-05-20 14:39:35

标签: jquery asp.net-mvc datasource kendo-combobox

我需要在其容器的Kendo.Combobox事件中填充Edit

我有一个为Kendo.Combobox定义EditTemplate的网格:

co.Bound(c => c.PropertyName).Title("Property Name").EditorTemplateName("_PropertyNameEditor");

组合框在EditTemplate中的定义如下:

@(Html.Kendo().ComboBox()
    .Name("ReportProperty")
    .DataTextField("PropertyName")
    .DataValueField("ReportPropertyID")
    .HtmlAttributes(new { id = "ReportPropertyCB" })
)

网格具有触发Edit JavaScript函数的事件:

.Events(events => events.DataBound("Databound").Edit("Edit"))

我需要在该Edit事件上填充组合框:

function Edit(e) {

    $.ajax({

        //url: "/TicketReportProperty/PopulateReportProperty",
        type: "GET",
        contentType: "application/json; charset=utf-8",
        datatype: "json",
        data: {'reportId' : @Html.Raw(Model.ReportID)},
        success: function (data)
        {
            $("idCB").html = '';
            if (data != '')
            {
               console.log(data);  
            if (data != '') {
                $(data.Data).each(function () {
                    console.log(this.PropertyName + " " + this.ReportGroup);
                    $("#ReportPropertyCB").append($("<option></option>").html(this.PropertyName));
                });                   
            }
            }
        }   
  });  
}

控制器的方法:

public JsonResult PopulateReportProperty([DataSourceRequest] DataSourceRequest request, int id)
{
    myModel model = new myModel();
    var dataList = model.GetDataList(id);
    return Json(rdata.ToList().ToDataSourceResult(request), JsonRequestBehavior.AllowGet);
}

在控制台上打印出返回的集合时,我有类似的东西: enter image description here

我该怎么做?

当生成html时,它看起来像这样:

enter image description here

它生成了,但没有在组合框中显示它们。

0 个答案:

没有答案