7

我正在使用验证插件。我想验证相同表单中的某些字段,当单选值不是“常规”时,

<form id="registerform">
<input type="radio" name="role" value="REGULAR" checked="checked" id="role">Regular<br />
<input type="radio" name="role" value="AGENT" id="role">Agent<br />
<input type="radio" name="role" value="ORGANIZATION" id="role">Organization<br />

<input type="text" name="phone"  id="phone"><br/>
<input type="text" name="password" id="password"><br/>

<input type="text" name="work_area" id="work_area" value=""><br/>
<input type="text" name="work_phone" id="work_phone" value=""><br/>

<input type="text" name="org_name" id="org_name"><br/>
<input type="text" name="org_phone" id="org_phone"><br/>
</form>

当角色==“常规”时,验证电话,密码
当角色==“代理”时,验证电话,密码,工作区域,工作电话
当角色==“组织”时,验证电话,密码,org_name,org_phone
如何优雅地实现这个?
我不想把它分成不同的形式!

我的错误代码:

$(document).ready(function() {
var rule_options = 
{
    "phone": "required"
    ,"password": "required"
};

var role = $("#registerform").find("input[name=role]:checked").val();
if(role ==  "AGENT") {
    $.extend(true, rule_options, 
        {
            "work_area": "required"
            ,"work_phone": "required"
        }
    );
}

if(role ==  "ORGANIZATION") {
    $.extend(true, rule_options, 
        {
            "org_area": "required"
            ,"org_phone": "required"
        }
    );
}
jform.validate({
            errorClass : "err_label",
            rules: rule_options,
            ignore: "",

上面的代码不起作用,因为它在 document.ready 之后只运行一次。
我一定遗漏了一些东西,一些语法..〜想法?

4

5 回答 5

10

jquery 验证规则
我从上面的链接中得到了我真正需要的东西。这里真正需要解决的是如何使 jQuery 验证器插件根据每个输入的无线电值动态地运行。我什至不使用 jQuery.change() 方法。

function getRole() {
    return $("#registerform").find("input[name=role]:checked").val();
}

$(document).ready(function() {
    var jform = $("#registerform");
    jform.validate({
            errorClass : "err_label",
            rules: 
                "phone": "required"
                ,"password": "required"
                ,"work_area": {
                    required: function(element) {
                        return (getRole() == 'AGENT');
                    }
                }
                ,"work_phone": {
                    required: function(element) {
                        return (getRole() == 'AGENT');
                    }
                }
                ,"org_name": {
                    required: function(element) {
                        return (getRole() == 'ORGANIZATION');
                    }
                }
                ,"org_phone": {
                    required: function(element) {
                        return (getRole() == 'ORGANIZATION');
                    }
                }

如果存在其他想法,请告诉我。

于 2013-02-11T14:36:42.643 回答
0

使用忽略选项。抱歉,如果有任何语法错误,因为我无法访问我的开发工具并且 jsfiddle 无法在我的计算机上运行。

编辑:我假设所有字段都是必需的。

$("form").validate({ignore: ".ignore"});

var role = {
    "REGULAR": ["work_area", "work_phone", "org_name", "org_phone"],
    "AGENT": ["org_name", "org_phone"],
    "ORGANIZATION": ["org_name", "org_phone"]
};

$("input[name=role]").click(function () {
    //reset ignore
    $("#work_area,#work_phone,#org_name,#org_phone").removeClass("ignore");

    for (var i in role[$(this).val()])
    {
        $(i).addClass("ignore");
    }
});
于 2013-02-11T10:00:06.027 回答
-1
$("input[@name='role']").change(function(){
    // Rest of your code here.
});

使用 onload 事件,将函数绑定到单选按钮。

于 2013-02-11T08:27:30.170 回答
-1

您可以在用户每次单击表单或在其上按一个键时更新验证规则。

function updateRules() {
  // Your code here
}

$('#registerform').click(function() {
  updateRules();
});

$('#registerform').keyUp(function() {
  updateRules();
});
于 2013-02-11T08:27:42.727 回答
-1

问题是你正在做:

var role = $("#registerform").find("input[name=role]:checked").val();

和它的工作,但只有一次,因为你需要将它附加到一个事件(也许更改事件是合适的),所以每次单选按钮以某种方式发生变化时,验证设置应该改变:

$("input[@name='role']").change(function(){
    if( $(this).is(":checked") ){ // check if the radio is checked
        var val = $(this).val(); // retrieve the value
        if(role ==  "AGENT") {
           $.extend(true, rule_options, {
              "work_area": "required"
             ,"work_phone": "required"});
        }
        if(role ==  "ORGANIZATION") {
           $.extend(true, rule_options, {
              "org_area": "required"
             ,"org_phone": "required"});
        }
    }
});
于 2013-02-11T08:47:54.573 回答