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