Ich arbeite mit diesem Kontaktformular.Formular-Validierung funktioniert nicht in Chrom noch Firefox
<form name="contact" action="mailto:[email protected]&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>
Und Javascript
function validateMail(mail) {
var re = /^(([^<>()[\]\\.,;:\[email protected]\"]+(\.[^<>()[\]\\.,;:\[email protected]\"]+)*)| (\".+\"))@((\[[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;
}
}
Dieser Code perfekt auf IE11 funktioniert (11.0.9600.18500), aber Chrom 54.0.2840.71 m (64-Bit) und FF 49.0.2 nur meinen Javascript ignorieren und fortfahren um die Mail mit leeren Feldern oder ungültigen Informationen zu senden.
PS: im für das Textfeld mit id, da ich es mit der Form [#] Option
bearbeiten finden können: Ich fand, dass der IE identifiziert richtig den Textbereich als [object HTML TextAreaElement] aber sowohl für Chrome und Firefox ist
undefined
Name Ihres Formulars ist, den Kontakt und Sie verwenden document.forms [ „Contacto“]; ist das ein Tippfehler ..? sollte das nicht sein document.forms ["contact"]; ..? –
Anstelle von 'onsubmit =" return validate() "' können Sie direkt 'onsubmit =" validate() "' verwenden. –
@HimanshuAgargarwal: Nein, du kannst nicht. Letzteres verhindert nicht das Senden des Formulars, wenn die Funktion false zurückgibt. – CBroe