maskedinput プラグインを使用すると、このような必須の電話番号フィールドを持つフォームがあります
(999) 999-9999
これを検証するために、jquery 検証でリテラルを無視するようにします。また、フォームが送信される前にリテラルを削除したいと考えています。しかし、検証エラーが発生した場合でも、maskedinput プラグインを有効にして、フォーマットがユーザーにとって正しいように見えるようにします。
検証のために正規表現を編集できると思いますが、フォームが送信されると、リテラルはまだそこにあります。
これをもっとよく説明する必要があることを教えてください。
何か案は?私はjqueryにかなり慣れていないので、詳細なソリューションはすべて素晴らしいでしょう。
私のJavaScriptコードはこれです
$(document).ready(function(){
jQuery.validator.addMethod("phoneUS", function(phone_number, element) {
phone_number = phone_number.replace(/\s+/g, "");
return this.optional(element) || phone_number.length > 9 &&
phone_number.match(/^(1-?)?(\([2-9]\d{2}\)|[2-9]\d{2})-?[2-9]\d{2}-?\d{4}$/);
}, "US Phone Number Required");
$("#valform").validate({
invalidHandler: function(form, validator) {
var errors = validator.numberOfInvalids();
if (errors) {
$("#error-message").show().text("Please correct the required field(s)");
} else {
$("#error-message").hide();
}
},
messages: {
phone: {
required: ""
}
},
rules: {
phone: {
required: true,
phoneUS: true
},
},
});
$("#phone").mask("(999) 999-9999",{placeholder:" "});
});