0

これ(ページの下部にあるもの)RegExpを実装して、jquery検証プラグインで電子メールアドレスを検証しようとしています。

これは私のコードです:

$.validator.addMethod("email_address", function(value, element, param) {
  var email_regexp = new RegExp("[a-z0-9!#$%&'*+/=?^_{|}~-]+(?:\.[a-z0-9!#$%&'*+/=?^_{|}~-]+)*@(?:a-z0-9?.)+(?:[A-Z]{2}|com|org|net|edu|gov|mil|biz|info|mobi|name|aero|asia|jobs|museum)\b", "g");
  var result = value.match(email_regexp);
  return result ? result.length >= param : false;
}, "Invalid email address");

JS エラーは表示されませんが、何も検証されません! 1時間ほど遊んでいますが、これを機能させることはできません!

何か問題がありますか?

編集://区切り文字も試しました:

$.validator.addMethod("email_address", function(value, element, param) {
  var result = value.match(/[a-z0-9!#$%&'*+/=?^_{|}~-]+(?:\.[a-z0-9!#$%&'*+/=?^_{|}~-]+)*@(?:a-z0-9?.)+(?:[A-Z]{2}|com|org|net|edu|gov|mil|biz|info|mobi|name|aero|asia|jobs|museum)\b/g);
  return result ? result.length >= param : false;
}, "Invalid email address");
4

2 に答える 2

2
~-]+(?:\.[a-z0-9!#$
//     ^^

Javascript\.文字列を再度エスケープする必要があります。

~-]+(?:\\.[a-z0-9!#$
//     ^^^

または、できれば、文字列からオブジェクトを//構築するのではなく、区切り文字を使用してください。RegExp

https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Global_Objects/RegExp

于 2013-01-09T15:10:35.590 に答える
1

emailjQuery Validate プラグインには既にルールが組み込まれているのに、なぜカスタム正規表現関数を作成しているのですか?

http://docs.jquery.com/Plugins/Validation/Methods/email

jQuery:

$(document).ready(function() {

    $('#myform').validate({
        rules: {
            field: {
                required: true,
                email: true
            }
        }
    });

});

HTML:

<form id="myform">  
     <input type="text" name="field" />  <br/>  
     <input type="submit" />
</form> 

作業デモ:

http://jsfiddle.net/sRwHc/


プラグイン内で使用されるデフォルトの正規表現関数.validate()、FYI:

email: function(value, element) {
    // contributed by Scott Gonzalez: http://projects.scottsplayground.com/email_address_validation/
    return this.optional(element) || /^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))$/i.test(value);
}
于 2013-01-09T17:48:36.287 に答える