如何使用JSON作为contentType来制作Kendo MVC Helpers的CRUD

时间:2016-04-29 08:34:40

标签: javascript jquery json asp.net-mvc kendo-asp.net-mvc

@(Html.Kendo().DropDownListFor(model => model.ServiceID)
  .OptionLabelTemplate("#=optionLabel#")
  .ValueTemplate("#=Code#(#=Rate#) - #=Description#")
  .Template("#=Code#(#=Rate#) - #=Description#")
  .DataTextField("Code")
  .DataValueField("ServiceID")
  .DataSource(d =>
  {
    d.Read(read =>
    {
      read.Action("GetServiceRepository", "Service").Data("...")
      .Type(HttpVerbs.Post);
    });  
  })
  .OptionLabel(new { optionLabel = Resources.Wording.SelectOne, ServiceID = 0, Rate = 0, Code = "" })
)

我有一个Kendo Dropdownlist,它使用HTML帮助方式而不是JQuery方式初始化。

是否有使用JSON作为contentType而不是默认application/x-www-form-urlencoded向/ Service / GetServiceRepository发布帖子请求?

2 个答案:

答案 0 :(得分:2)

您可以使用DataSource的自定义 fluent方法设置ContentType属性。我使用版本2016.2.504。

用法是:

 @(Html.Kendo().DropDownListFor(model => model.ServiceID)
  .DataTextField("Text")
  .DataValueField("Value")
  .DataSource(d => d.Custom()
    .Transport(c => c.Read(
      read => read.ContentType("xml/json")
          .Data("...")
          .Type(HttpVerbs.Post)
          .Action("GetServiceRepository", "Service")))
  ))

答案 1 :(得分:2)

此Kendo MVC Helper不支持设置内容类型。它旨在与MVC控制器和Kendo MVC服务器API一起使用,因此不能设置所有请求选项。您应该使用JavaScript初始化以便能够设置所有选项。在帮助器初始化之后,可以通过JavaScript修改选项,例如

$(function () {
    var grid = $("#grid").data("kendoGrid");
    grid.dataSource.transport.options.update.contentType = "application/json";
    //override the parameterMap function in order to convert the data to JSON
    grid.dataSource.transport.parameterMap = function (options, type) {
        return kendo.stringify(options);
    }
});