如何将模型绑定到 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)
我正在尝试使用我的 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)