如何将模型绑定到 kendo 组合框以使用模型验证?

How to bind a model to a kendo Combobox in order to use the models validatation?

我正在尝试使用我的 viewModel 来验证客户端和服务器端的表单。除了我的 Kendo 组合框,我已经完成了所有验证工作。我已将模型绑定到多选,但我不知道如何区分列表和所选值。

组合框:

@(Html.Kendo().ComboBox()
    .Name("roleRequest_UnavailableRoles")
    .BindTo(new SelectList(Model.roleRequest.UnavailableRoles, "Value", "Text"))
    .HtmlAttributes(new { name="addRoleName", style = "width:250px", required = true, roleValidationMessage = "foo" })
    .Value(Model.roleRequest.roleName)
    .DataTextField("Text")
    .DataValueField("Value")
    .Filter(FilterType.StartsWith)
    .Placeholder("Select Role...")
    .AutoBind(false)
    .Suggest(true)
)

查看模型:

[Required]
    public string roleName { get; set; }

    [Required]
    public string usersName { get; set; }

    [Required]
    public string application { get; set; }

    [Required]
    public string reasons { get; set; }

    public virtual IEnumerable<SelectListItem> UnavailableRoles
    {
        get
        {
            var unavailableList = new List<Role>();

            unavailableList = RoleHelper.GetUnavailableRoles(usersName, application);

            var unavailableRolesList = (unavailableList.Distinct());

            var UnavailableRoles = new List<SelectListItem>();

            foreach (var role in unavailableRolesList)
            {
                UnavailableRoles.Add(new SelectListItem
            {
                Value = role.RoleID.ToString(),
                Text = role.RoleName
            });
            }


            return new SelectList(UnavailableRoles, "Value", "Text");
        }
    }

控制器: [HttpPost] public ContentResult RoleRequest(AddRoleRequestViewModel viewModel) { 如果(ModelState.IsValid) { return内容(“1”); } return 内容(""); }

上面的代码确实可以编译,但是如果没有在组合框中选择任何项目,我无法让控制器 return 无效。谁能解释如何解决这个问题?

如有任何帮助,我们将不胜感激。

如果您使用 Html.Kendo().ComboBoxFor(),您可以将它绑定到一个模型 属性,类似于:

@(Html.Kendo().ComboBoxFor(m => m.UnavailableRoles)
    .Name("roleRequest_UnavailableRoles")
    .BindTo(new SelectList(Model.roleRequest.UnavailableRoles, "Value", "Text"))
    .HtmlAttributes(new { name="addRoleName", style = "width:250px", required = true, roleValidationMessage = "foo" })
    .Value(Model.roleRequest.roleName)
    .DataTextField("Text")
    .DataValueField("Value")
    .Filter(FilterType.StartsWith)
    .Placeholder("Select Role...")
    .AutoBind(false)
    .Suggest(true)
)

请注意,执行此操作时,您不需要 Name()Value() 属性,因为它们将在使用 ComboBoxFor()

时处理

这将负责将控件绑定到模型,还允许您使用验证。

此外,我在您的模型中遗漏了一件事:您需要另一个 属性 作为实际值(除了选项之外)。我会做这样的事情:

public List<Guid> RoleIds { get; set; } // or List<int> if you're using integers

然后将您的 ComboBoxFor 更改为 ComboBoxFor(x => x.RoleIds)