【问题标题】:regex not working for ZipCode正则表达式不适用于邮政编码
【发布时间】:2023-05-02 11:24:02
【问题描述】:

HTML

<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"
        }
    });
});

问题:邮政编码存在一些问题。它总是在说。请输入有效的邮政编码。但是当我用 s/w 测试正则表达式时,它在那里工作正常......

JSFiddle - Demo

【问题讨论】:

  • 您是否使用警报或日志语句来确定您的验证函数正在接收的确切字符串?
  • 是的。传递和接收的测试字符串是 12345。
  • 我问是因为我想知道是否有前导或尾随“隐藏”字符通过并破坏您的“^”和“$”部分......我假设一个有效的 CA zip 展品同样的行为?
  • 你能检查一下我的小提琴吗?

标签: jquery asp.net-mvc asp.net-mvc-3 validation jquery-validate


【解决方案1】:

我做了一些改动,现在工作正常

<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>

【讨论】:

    【解决方案2】:

    在 Javascript 中,您必须转义所有 Javascript 本身不使用的转义字符。用正则表达式中的双反斜杠替换所有反斜杠,或者(如该答案中的 OP 所述)表示使用正斜杠作为边界字符的正则表达式,而不是将其列为 javascript 将尝试解释的字符串。正斜杠是显式编写new Regexp("..."); 的语法糖。

    【讨论】:

    • 我的手机不容易。您可能需要尝试其他可能需要转义的字符,如果只是转义反斜杠不起作用......我所做的只是在发现数字匹配本身不起作用后尝试了“\\d” ...
    最近更新 更多