Jquery检查输入.val()是否包含某些字符
我需要检查我的页面上的输入字段是否包含字符。
这是非常基本的电子邮件地址validation,所以我只想检查文本是否为空,并包含@
和.
字符。
我一直在尝试这种方式:
if (($("." + parentname.attr("class") + " #email").val().contains("@")) && ($("." + parentname.attr("class") + " #email").val().contains("."))) { email = 1; }
假设值为me@this.com
,此代码将抛出以下错误:
对象me@this.com没有’包含’的方法
所以我做了一些研究,发现.contains用于DOM对象,而不是字符串,建议尝试这样做:
if (($("." + parentname.attr("class") + " #email").val().IndexOf("@") != -1) && ($("." + parentname.attr("class") + " #email").val().IndexOf(".") != -1)) { email = 1; }
这会导致类似的错误:
对象me@this.com没有方法’IndexOf’
我基本上没有想法,特别是考虑到以下代码在我做的另一个网站中的工作原理:
if ($("#contact-email").val().contains("yahoo.com")) { $(".errmsg").text("Domain yahoo.com has been banned due to excessive spam, please use another domain."); }
任何人都可以建议我可以尝试的任何其他事情,或者更好的是,如何正确地做到这一点?
indexOf
在开始时不使用大写indexOf
I. 试试这个:
if (($("." + parentname.attr("class") + " #email").val().indexOf("@") != -1) && ($("." + parentname.attr("class") + " #email").val().indexOf(".") != -1)) { email = 1; }
我有一个函数来validationJavascript中的电子邮件:
function isEmail(emailV){ if(emailV != null && emailV != undefined){ var pattern = new RegExp(/^((([az]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([az]|\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)))@((([az]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([az]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([az]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([az]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([az]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([az]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([az]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([az]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i); return pattern.test(emailV); } else{ return false; } }
它validation电子邮件允许的所有字符,您只需要像这样调用它:
if(isEmail($("#contact-email").val())){ //EMAIL IS VALID } else{ //EMAIL IS NOT VALID }
方法是indexOf
而不是IndexOf
。 如果你纠正你的代码,它应该像魅力:)。
试试这段代码:
if (($("." + parentname.attr("class") + " #email").val().indexOf("@") !== -1) && ($("." + parentname.attr("class") + " #email").val().indexOf(".") !== -1)) { email = 1; }
现场演示
// VISUALIZE ERRORS function showError(el, err){ return err ? $(el).addClass('error') : $(el).removeClass('error'); } // REGEXES var isValidEmailAddress = function( emailAddress ) { var pattern = new RegExp(/^((([az]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([az]|\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)))@((([az]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([az]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([az]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([az]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([az]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([az]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([az]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([az]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i); return pattern.test(emailAddress); }; // "EMAIL" function validate_email( el, val ){ var err = !isValidEmailAddress( val ); showError(el, err); } $('#email').on('input', function(){ validate_email( this, this.value ); });