Your code:
var testRules = "{ col1: { required: true},col2: {maxlength: 50}}";
Just get rid of the quotation marks and it will work fine.
var testRules = { col1: { required: true},col2: {maxlength: 50}};
DEMO: http://jsfiddle.net/mNtcL/
For the purposes of my example, this is the base starting code:
HTML:
<input type="text" name="field_1" />
<input type="text" name="field_2" />
<input type="text" name="field_3" />
JS:
$('#myForm').validate({
rules: {
field_1: {
required: true,
number: true
},
field_2: {
required: true,
number: true
},
field_3: {
required: true,
number: true
}
}
});
DEMO: http://jsfiddle.net/rq5ra/
Yes, you can pull out the groups of rules and combine them into common variables.
var ruleSet1 = {
required: true,
number: true
};
$('#myForm').validate({
rules: {
field_1: ruleSet1,
field_2: ruleSet1,
field_3: ruleSet1
}
});
DEMO: http://jsfiddle.net/rq5ra/4/
You can also use .extend() to recombine them in an infinite numbers of ways.
var ruleSet_default = {
required: true,
number: true
};
var ruleSet1 = {
max: 99
};
$.extend(ruleSet1, ruleSet_default); // combines defaults into set 1
var ruleSet2 = {
min: 3
};
$.extend(ruleSet2, ruleSet_default); // combines defaults into set 2
$('#myForm').validate({
rules: {
field_1: ruleSet2,
field_2: ruleSet_default,
field_3: ruleSet1
}
});
End Result:
field_1 will be a required number no less than 3.
field_2 will just be a required number.
field_3 will be a required number no greater than 99.
DEMO: http://jsfiddle.net/rq5ra/5/
Also see this answer for more ways to apply rules.