【问题标题】:KendoUI Editor template for Drop-down not working for add items option下拉菜单的 KendoUI 编辑器模板不适用于添加项目选项
【发布时间】:2014-08-23 19:51:49
【问题描述】:

我有一个包含 4 列的 KendoUI Web 界面 1-环境名称,2-环境代码 3-服务器详细信息 4-项目详细信息 他们都使用 editor template dropdown 来显示除 Environment-name 之外的值,它只是一个文本字段。 当我单击 Edit 并从所有三个下拉列表中选择值时,它会将值完美地发送到控制器并更新数据库。但如果我点击 Add New Item Button 时,Server-details 下拉菜单和 Project details 下拉菜单不会将值发送到控制器。

这是 cs-html 文件。

 @(Html.Kendo().Grid<EnvironmentPOCO>()
          .Name("Grid")
          .Columns(columns =>
          {
              columns.Bound(d => d.EnvironmentName).Width(200).Title("Environment Name");
              columns.ForeignKey(d => d.EnvironmentTypeID, (List<EnvironmentTypePOCO>)ViewData["EnvironmentType"], "EnvironmentTypeID", "EnvironmentTypeCode").Width(150).Title("Environment Code").EditorTemplateName("_EnvironmentCodeDropDown");
              columns.ForeignKey(d => d.Server_ID, (List<ServerPOCO>)ViewData["Servers"], "Server_ID", "ServerName").Width(300).Title("Server Details").EditorTemplateName("_ServerDropDown");
              columns.ForeignKey(d => d.Project_ID, (List<SynergyProjectPOCO>)ViewData["SynergyProjects"], "Project_ID", "ProjectName").Width(400).Title("Project Details").EditorTemplateName("_ProjectNameDropDown");         
             // columns.ForeignKey(d => d.ServerID, (List<ServerPOCO>)ViewData["ServerDetails"], "ServerID", "ServerIP").Width(200).Title("Server IP")/*.EditorTemplateName("_ServerIPDropDown")*/;
             // columns.ForeignKey(d => d.ProjectID, (List<SynergyProjectPOCO>)ViewData["SynergyProjects"], "ProjectID", "ProjectDescription").Width(200).Title("ProjectDescription")/*.EditorTemplateName("_ProjectDescription")*/;
              columns.Command(d =>
              {
                  d.Edit();
                  d.Destroy();

              }).Width(200).Title("Action");
          }

          )

          .ToolBar(tools => tools.Create())
          .Sortable()
          .Pageable()
          .AutoBind(true)
          .Filterable()
          //.Scrollable()
          .DataSource(dataSource => dataSource
            .Ajax()
                .Model(model =>
                    {
                        model.Field(m => m.EnvironmentTypeID);

                        model.Field(m => m.Server_ID);                  

                        model.Field(m => m.Project_ID);
                        model.Field(m => m.EnvironmentName);
                        model.Id(m => m.EnvironmentID);

                    })
                .Read(read => read.Url(ViewBag.ApiBaseUrl).Type(HttpVerbs.Get))
                .Create(create => create.Url(ViewBag.ApiBaseUrl).Type(HttpVerbs.Post))
                .Update(update => update.Url(ViewBag.ApiBaseUrl).Type(HttpVerbs.Put))
                .Destroy(destroy => destroy.Url(ViewBag.ApiBaseUrl).Type(HttpVerbs.Delete))
          )

    )

_EnvironmentCodeDropDown 编辑器模板

@(Html.Kendo().DropDownListFor(m => m)
                  .Name("EnvironmentTypeID")
                  .OptionLabel("Select Envrionment Type")
                  .DataTextField("EnvironmentTypeCode")
                  .DataValueField("EnvironmentTypeID")
                  .BindTo((List<EnvironmentTypePOCO>)ViewData["EnvironmentType"])
            )

_ProjectNameDropDown 编辑器模板 @使用 List.Model.Model

@(Html.Kendo().DropDownListFor(m => m)
                  .Name("Project_ID")
                  .OptionLabel("Select Project Name")
                  .DataTextField("ProjectName")
                  .DataValueField("Project_ID")
                  .BindTo((List<SynergyProjectPOCO>)ViewData["SynergyProjects"])
            )

_ServerDropDown EditorTemplate @使用 List.Model.Model

@(Html.Kendo().DropDownListFor(m => m)
                  .Name("Server_ID")
                   .OptionLabel("Select Server")

                  .DataTextField("ServerName")
                  .DataValueField("Server_ID")
                  .BindTo((List<ServerPOCO>)ViewData["Servers"])
            )

【问题讨论】:

  • 不确定是什么问题。您是说当您单击添加新并输入记录的详细信息并提交时,那些新记录的详细信息或未发布到控制器?创建方法的 ViewBag.ApiBaseUrl 是什么?您是否使用相同的 URL 进行创建、编辑和销毁?

标签: razor kendo-ui kendo-asp.net-mvc


【解决方案1】:

我看不出上面的代码有什么问题,你的数据库肯定有问题。请检查您的数据库外部列必须设置为非空。这可能会解决您的问题。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2017-04-03
    • 1970-01-01
    • 2017-02-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-09-02
    • 2021-09-05
    相关资源
    最近更新 更多