表单验证不适用于chrome或firefox

时间:2016-10-25 10:20:44

标签: javascript jquery google-chrome firefox

我正在使用此联系表单。

<form name="contact" action="mailto:me@me.com&subject=subject&body=message"  
 onsubmit="return validate()" method="post" enctype="text/plain">
<label for="mail">Your mail address *</label>
<input type="text" name="mail"/></br></br>
<label for="subject">Subject *</label>
<input type="text" name="subject"/></br>
<label for="message">Your message *</label>
<textarea id="txtarea" name="message" form="contact"></textarea>
<input type="submit" value="Send"/>
</form>

这个javascript

function validateMail(mail) {
var re = /^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|     (\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;
return re.test(mail);
}
function validate(){
var x = document.forms["contact"];  
if (x[0].value == null || x[0].value == ""){
    alert("Your mail address");
    return false;
}else{
    if(!validateMail(x[0].value)){
        alert("mail address not valid");
        return false;
    }
}
if(x[1].value == null || x[1].value == ""){
    alert("Add a subject");
    return false;
}
if(x['txtarea'].value.length < 1 || x['txtarea'].value == '' || x['txtarea'].value == null){
    alert("Add your message");
    return false;
}  
}

此代码在IE11(11.0.9600.18500)上完美运行,但chrome 54.0.2840.71 m(64位)和FF ​​49.0.2只是忽略我的javascript并继续发送包含空字段或无效信息的邮件。

PS:即时通讯使用id为textarea,因为我无法使用[#]选项找到它

编辑:我发现IE正确地将textarea标识为[object HTML TextAreaElement]但是chrome和firefox都是未定义的

2 个答案:

答案 0 :(得分:0)

使用以下方法管理解决它:

if(document.getElementById('txtarea').value.length < 1 || document.getElementById('txtarea').value == '' || document.getElementById('txtarea').value == null)

而不是:

if(x['txtarea'].value.length < 1 || x['txtarea'].value == '' || x['txtarea'].value == null)

因为chrome或firefox都无法正确处理表单['id']

答案 1 :(得分:0)

问题在于您的textarea,请从中删除form="contact"。您可以使用以下表格 -

<form name="contact" action="mailto:me@me.com&subject=subject&body=message" onsubmit="return validate()" method="post" enctype="text/plain">
    <label for="mail">Your mail address *</label>
    <input type="email" name="mail" /></br>
    </br>
    <label for="subject">Subject *</label>
    <input type="text" name="subject" /></br>
    <label for="message">Your message *</label>
    <textarea id="txtarea" name="message"></textarea>
    <input type="submit" value="Send" />
</form>

这里有一些针对您的表单的优化Javascript函数 -

function validateMail(mail) {
    var re = /^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|     (\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;
    return re.test(mail);
}

function validate() {
    var x = document.forms["contact"];
    if (!x[0].value) {
        alert("Your mail address");
        return false;
    } else {
        if (!validateMail(x[0].value)) {
            alert("mail address not valid");
            return false;
        }
    }
    if (!x[1].value) {
        alert("Add a subject");
        return false;
    }
    if (!x['txtarea'].value) {
        alert("Add your message");
        return false;
    }
}