验证中需要两个字段中的一个

时间:2013-04-10 16:29:21

标签: c# asp.net-mvc model-view-controller

我有两个字段:

  

     

名字

只需要其中一个。但如果两者都省略,我希望两个字段都突出显示。如果填写了其中一个,那么模型就可以了,表格应该提交。

如何做到这一点?

3 个答案:

答案 0 :(得分:3)

您可以使用this library,它可以帮助您做这样的事情

[RequiredIf("PropertyValidationDependsOn", true)]
   public string PropertyToValidate { get; set; }

答案 1 :(得分:3)

所有复杂验证都从您继承自 IValidatableObject 的视图模型开始。然后,您覆盖验证并输入您自己的验证规则。

IEnumerable<ValidationResult> IValidatableObject.Validate(ValidationContext validationContext)
{
    if (String.IsNullOrWhiteSpace(FirstName) && String.IsNullOrWhiteSpace(LastName))
    {
        yield return new ValidationResult("A name must be entered.", new string[] { "FirstName", "LastName" });
    }
}

请注意,这仅确保此规则的服务器端验证。如果你想要客户端,你需要编写自己的JavaScript / jQuery代码来处理验证。

答案 2 :(得分:2)

如果您愿意在客户端执行此操作 这可能会给你一个开始

HTML

<input type="text" class="name" id="firstName" />
<input type="text" class="name" id="lastName" />
<input type="button" id="btnSubmit" value="submit" />

按钮单击事件

$("#btnSubmit").click(function () {
    var isValid = false;
    $("input[class='name']").each(function (key, keyValue) {
        //alert(keyValue.value);
        if (keyValue.value.length > 0) {
            isValid = true;
            $(this).css("background", "White");
        }
        else {
            $(this).css("background", "RED");
        }
    })
    if (!isValid) {
        // do something 
    }
});

如果未通过验证,则阻止表单提交

$('input[type=submit]').bind('click', function(e) {
   var isValid = false;
        $("input[class='name']").each(function (key, keyValue) {
            //alert(keyValue.value);
            if (keyValue.value.length > 0) {
                isValid = true;
                $(this).css("background", "White");
            }
            else {
                $(this).css("background", "RED");
            }
        })
        if (!isValid) {
           e.preventDefault() // prevents the form from being submitted
        }    
});

http://jsfiddle.net/habo/UpmCv/

进行测试