asp.net-mvc-3 – 如何将复选框绑定到mvc3中的viewmodel
发布时间:2020-12-15 16:10:12 所属栏目:asp.Net 来源:互联网
导读:我真的很努力地围绕着这个: 我有一个UserModel和一个UserRoleModel: public class UserModel{ [Required] [Display(Name = User name)] public string UserName { get; set; } [Required] [DataType(DataType.E
我真的很努力地围绕着这个: 我有一个UserModel和一个UserRoleModel: public class UserModel { [Required] [Display(Name = "User name")] public string UserName { get; set; } [Required] [DataType(DataType.EmailAddress)] [Display(Name = "Email address")] public string Email { get; set; } [Required] [StringLength(100,ErrorMessage = "The {0} must be at least {2} characters long.",MinimumLength = 6)] [DataType(DataType.Password)] [Display(Name = "Password")] public string Password { get; set; } [DataType(DataType.Password)] [Display(Name = "Confirm password")] [Compare("Password",ErrorMessage = "The password and confirmation password do not match.")] public string ConfirmPassword { get; set; } public IEnumerable<string> UserRoles { get; set; } } public class UserRoleModel { public IEnumerable<string> AllRoles { get; set; } public UserModel user { get; set; } public UserRoleModel() { this.AllRoles = Roles.GetAllRoles(); this.user = new UserModel(); } } 在控制器中: public ActionResult Create() { return View(new UserRoleModel()); } [HttpPost] public ActionResult Create(UserRoleModel model) { if (ModelState.IsValid) { MembershipCreateStatus createStatus; Membership.CreateUser(model.user.UserName,model.user.Password,model.user.Email,null,true,out createStatus); if (createStatus == MembershipCreateStatus.Success) { foreach (var r in model.AllRoles) { Roles.AddUserToRole(model.user.UserName,r); } return RedirectToAction("Index","Home"); } else { ModelState.AddModelError("",ErrorCodeToString(createStatus)); } } return View(model); } 和视图: @model BBmvc.Areas.Tools.Models.UserRoleModel 和: @using (Html.BeginForm()) { @Html.ValidationSummary(true) <fieldset> <legend>UserModel</legend> <div class="editor-label"> @Html.LabelFor(model => model.user.UserName) </div> <div class="editor-field"> @Html.EditorFor(model => model.user.UserName) @Html.ValidationMessageFor(model => model.user.UserName) </div> <div class="editor-label"> @Html.LabelFor(model => model.user.Email) </div> <div class="editor-field"> @Html.EditorFor(model => model.user.Email) @Html.ValidationMessageFor(model => model.user.Email) </div> <div class="editor-label"> @Html.LabelFor(model => model.user.Password) </div> <div class="editor-field"> @Html.EditorFor(model => model.user.Password) @Html.ValidationMessageFor(model => model.user.Password) </div> <div class="editor-label"> @Html.LabelFor(model => model.user.ConfirmPassword) </div> <div class="editor-field"> @Html.EditorFor(model => model.user.ConfirmPassword) @Html.ValidationMessageFor(model => model.user.ConfirmPassword) </div> <div class="editor-field"> @foreach (var r in @Model.AllRoles) { @Html.CheckBox(r,false) @Html.Label(r) <br /> } </div> <p> <input type="submit" value="Create" /> </p> </fieldset> } 首先,我无法从我的viewModel中找出如何使用CheckBoxFor.但它显示复选框选项,所以我可以与它一起生活.但是,我无法确定如何确定哪个复选框在表单发布时被检查.我也似乎破坏了客户端验证,我假设因为我使用viewModel. 解决方法CheckBoxFor助手以布尔属性运行.所以你可以定义一个视图模型:public class RoleViewModel { public string Name { get; set; } public bool Selected { get; set; } } 然后在视图模型上修改AllRoles属性: public class UserRoleModel { public IEnumerable<RoleViewModel> AllRoles { get; set; } public UserModel user { get; set; } public UserRoleModel() { this.AllRoles = Roles.GetAllRoles().Select(r => new RoleViewModel { Name = r }); this.user = new UserModel(); } } 而在视图中而不是编写foreach循环使用编辑器模板: <div class="editor-field"> @Html.EditorFor(x => x.AllRoles) </div> 最后定义一个RoleViewModel类型的编辑器模板,它将自动为AllRoles集合的每个元素呈现(/ Views / Shared / EditorTemplates / RoleViewModel.cshtml) @model RoleViewModel @Html.CheckBoxFor(x => x.Selected) @Html.LabelFor(x => x.Selected,Model.Name) @Html.HiddenFor(x => x.Name) <br /> 就这样.在Post操作中,您将获得使用值填充的AllRoles属性. (编辑:百色站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- asp.net-mvc – ASP.NET MVC WebSite中的ERR_EMPTY_RESPONS
- asp.net-mvc – MVC3验证与实体框架模型/数据库首先
- 受asp.net MVC启发的更好的WebForms
- asp.net-mvc – 使用AWS .NET SDK进行SNS订阅确认示例
- ASP.NET对大文件上传的解决方案
- asp.net-mvc-3 – 如何在Razor视图引擎中注册程序集
- asp.net使用H5新特性实现异步上传的示例
- ASP.NET Core 1.0 ConfigurationBuilder().AddJsonFile(“a
- asp.net – 更改事件和IE8的jQuery问题
- ASP.Net WebAPI与Ajax进行跨域数据交互时Cookies数据的传递
推荐文章
站长推荐
- asp.net-mvc – 用于选择的KendoUI网格Ajax绑定参
- asp.net-mvc-4 – 全局过滤器MVC 4的执行顺序是什
- IIS和ASP.Net Web开发服务器之间的行为差异?
- 集成ASP.NET Webforms,WebAPI和AngularJS
- asp.net – 在MVC 4.0中使用部分视图中的节
- asp.net – CalendarExtender定位问题
- ASP.Net中的图形(c#)
- ASP.NET和System.Diagnostics跟踪 – 我错过了什
- 如何设置特定于ASP.NET请求的log4net上下文属性?
- asp.net-mvc – 无法更改关系,因为一个或多个外键
热点阅读