MVC3 单选按钮验证

Posted

技术标签:

【中文标题】MVC3 单选按钮验证【英文标题】:MVC3 radio buttons validation 【发布时间】:2012-10-18 21:34:49 【问题描述】:

我有一个关于单选按钮和检查的问题。

首先,在我看来,我有一个带有登录值的文本框。在这个文本框和提交按钮之间,我有 5 个单选按钮。这些 rb 中的每一个都引用了我的 ViewModel 中的一个属性。

所以这里是代码。 我的 ViewModel 的属性:

public class DeleteUAInfosViewModel


    [Display(Name = "UserAccountDeleteInfos", ResourceType = typeof(UserAccountResources))]
    public string UserLeave
    
        get  return UserAccountResources.UserLeave; 
    

    [Display(Name = "UserAccountDeleteInfos", ResourceType = typeof(UserAccountResources))]
    public string UserTransfer
    
        get  return UserAccountResources.UserTransfer; 
    

    [Display(Name = "UserAccountDeleteInfos", ResourceType = typeof(UserAccountResources))]
    public string UserDetachment
    
        get  return UserAccountResources.UserDetachment; 
    

    [Display(Name = "UserAccountDeleteInfos", ResourceType = typeof(UserAccountResources))]
    public string UserRetirement
    
        get  return UserAccountResources.UserRetirement; 
    

    [Display(Name = "UserAccountDeleteInfos", ResourceType = typeof(UserAccountResources))]
    public string UserStatus
    
        get  return UserAccountResources.UserStatus; 
    

我在其中链接 DeleteUAInfosViewModel 的 IndexViewModel:

public class IndexViewModel

        [Display(Name = "DeleteUAInfos", ResourceType = typeof(UserAccountResources))]
        public DeleteUAInfosViewModel DeleteUAInfosGroup  get; set; 

        public IndexViewModel()
        
            DeleteUAInfosGroup = new DeleteUAInfosViewModel();
        

        ...

我的部分视图与 rb 的声明:

@model MyPath.UserAccount.DeleteUAInfosViewModel

<div id="UserDeleteInfosField">
    <p>
        @html.RadioButton("RbDeleteGroup", Model.UserLeave)
        @UserAccountResources.UserLeave
        @Html.HiddenFor(x => x.UserLeave)   
    </p>
    <br />
    <p>
        @Html.RadioButton("RbDeleteGroup", Model.UserTransfer)
        @UserAccountResources.UserTransfer
        @Html.HiddenFor(x => x.UserTransfer)   
    </p>
    <br />
    <p>
        @Html.RadioButton("RbDeleteGroup", Model.UserDetachment)
        @UserAccountResources.UserDetachment
        @Html.HiddenFor(x => x.UserDetachment)   
    </p>
    <br />
    <p>
        @Html.RadioButton("RbDeleteGroup", Model.UserRetirement)
        @UserAccountResources.UserRetirement
        @Html.HiddenFor(x => x.UserRetirement)   
    </p>
    <br />
    <p>
        @Html.RadioButton("RbDeleteGroup", Model.UserStatus)
        @UserAccountResources.UserStatus
        @Html.HiddenFor(x => x.UserStatus)   
    </p>
</div>

我用这条线在另一个视图中调用这个局部视图:

@Html.Partial("_DeleteUAInfos", Model.DeleteUAInfosGroup)

目前我检查了登录名是空还是空。

但现在我需要包括对单选按钮的检查。 示例:我想验证登录是否正确并且至少检查了一个 rb(并检索了值)。

换句话说:我想将单选按钮的检查与登录值的检查结合起来(在我的例子中,登录部分已经完成)。

那么你能帮我解决这个问题吗?

提前致谢!

Ars_n

【问题讨论】:

【参考方案1】:

你所做的只是创建一个非常长的布尔表达式,所以在验证你的登录的函数中添加

if(!radio1&&!radio2...&&!radion)

    ModelState.AddModelError("HTMLModelComponentYouWantToValidate", "ErrorMessage");

然后在继续之前添加

if(ModelState.IsValid)...
else return View();

【讨论】:

只要你有权限,记得点赞并批准它是否适合你。 感谢您的回答。但我有几个问题:1)我的 rb 是字符串属性,那么我该怎么做呢? 2)如何在控制器中直接调用这些rb? 因此,当您处理此问题时,您应该使用表单提交。对于其中的每一个,请使用:@Html.RadioButtonFor(m=>m.UserLeave, Wantedvalue)。当您选择收音机并提交表单时,您可以检查每个值中的值,如果它与想要的值匹配,那么 Boom!已经检查过了。【参考方案2】:

最后我完全改变了做事的方式,使用枚举。 所以,我按照以下步骤操作:

1) 在 ViewModel 中声明一个公共枚举(其中包含“UserLeave”、“UserTransfer”等)。

2) 使用属性引用枚举(在 ViewModel 中):public MyEnum myEnum get; set;

3) 在视图中调用这个枚举:@Html.RadioButtonFor(m =&gt; m.myEnum, MyEnum.UserLeave); 对每个单选按钮重复此操作。

4) 现在,我可以直接在我的 ViewModel 中执行检查(是否选中单选按钮)..

所以我希望它能帮助遇到同样问题的人..

问候,

Ars_n

【讨论】:

以上是关于MVC3 单选按钮验证的主要内容,如果未能解决你的问题,请参考以下文章

离子单选按钮验证

单选按钮验证

如何在单选按钮后显示验证消息?

验证动态单选按钮jQuery

单选按钮验证(动态名称)

javascript中的单选按钮验证