<form action="#" id="MyForm" name="MyForm">
<p id="message"></p>
<table id="tblData">
<tr>
<td>
<label for="A">
A</label>
<input id="A" name="A" type="text" value="" />
</td>
</tr>
<tr>
<td>
<label for="ZipCode">
Zip Code</label>
<input id="ZipCode" name="ZipCode" type="text" value="" />
</td>
</tr>
<tr>
<td>
<span id="submitButton" class="k-button">Next</span>
</td>
</tr>
</table>
</form>JQuery
$(document).ready(function () {
$('#submitButton').click(function () {
$('#MyForm').submit();
});
$.validator.addMethod(
'regex',
function (value, element, regexp) {
var re = new RegExp(regexp);
return this.optional(element) || re.test(value);
}, "");
$('#MyForm').validate(
{
rules: {
A:
{
required: false,
range: [1, 9999999999]
}
},
messages: {
A: {
range: jQuery.validator.format("Please enter a value between {0} and {1}.")
}
}
,
highlight: function (element) {
$(element).closest('.MyForm').removeClass('success').addClass('error');
}
});
$("#ZipCode").rules("add", { regex: "^(\d{5}-\d{4}|\d{5}|\d{9})$|^([a-zA-Z]\d[a-zA-Z]( )?\d[a-zA-Z]\d)$",
messages: {
regex: "Zip code must be a Valid US or CA Zip"
}
});
});问题:Zip存在一些问题。它总是在说。请输入有效的邮政编码。但当我用s/w测试正则表达式时,它在那里工作得很好.

JSFiddle -演示
发布于 2013-09-13 15:20:52
我做了一些改变,现在工作得很好。
<script type="text/javascript">
$("#ZipCode").rules("add",
{ regex: /^(\d{5}-\d{4}|\d{5}|\d{9})$|^([a-zA-Z]\d[a-zA-Z]( )?\d[a-zA-Z]\d)$/,
messages: {
regex: "Zip code must be a Valid US or CA Zip"
}
});
$.validator.addMethod(
'regex',
function (value, element, regexp) {
return regexp.test(value);
}, "");
</script>发布于 2013-09-13 14:33:03
在Javascript中,必须转义Javascript本身没有使用的所有转义字符。将所有反斜杠替换为regex中的双反斜杠,或者(如OP在该答案中所指出的)表示使用正斜杠作为边界字符的regex,而不是将其作为javascript将试图解释的字符串列出。正斜杠是显式编写new Regexp("...");的语法糖。
https://stackoverflow.com/questions/18788387
复制相似问题