Wie kann ich eine E-Mail-Adresse in JavaScript am besten mit einem regulären Ausdruck überprüfen?
Antworten
Zu viele Anzeigen?Eine Lösung, die die Existenz der TLD nicht überprüft, ist unvollständig.
Fast alle Antworten auf diese Frage schlagen die Verwendung von Regex zur Überprüfung von E-Mail-Adressen vor. Ich denke, dass Regex nur für eine rudimentäre Validierung geeignet ist. Es scheint, dass die Überprüfung der Gültigkeit von E-Mail-Adressen eigentlich zwei separate Probleme sind:
1- Validierung des E-Mail-Formats: Sicherstellen, dass die E-Mail dem Format und Muster von E-Mails in RFC 5322 entspricht und dass die TLD tatsächlich existiert. Eine Liste aller gültigen TLDs finden Sie unter aquí .
Zum Beispiel, obwohl die Adresse example@example.ccc
den Regex erfüllt, handelt es sich nicht um eine gültige E-Mail, da ccc
ist keine Top-Level-Domain der IANA.
2- Sicherstellen, dass die E-Mail tatsächlich existiert: Um dies zu tun, die einzige Möglichkeit es um den Benutzern eine E-Mail zu senden .
Verwenden Sie diesen Code innerhalb Ihrer Validierungsfunktion:
var emailID = document.forms["formName"]["form element id"].value;
atpos = emailID.indexOf("@");
dotpos = emailID.lastIndexOf(".");
if (atpos < 1 || ( dotpos - atpos < 2 ))
{
alert("Please enter correct email ID")
return false;
}
Andernfalls können Sie jQuery . Innere Regeln definieren:
eMailId: {
required: true,
email: true
}
var testresults
function checkemail() {
var str = document.validation.emailcheck.value
var filter = /^([\w-]+(?:\.[\w-]+)*)@((?:[\w-]+\.)*\w[\w-]{0,66})\.([a-z]{2,6}(?:\.[a-z]{2})?)$/i
if (filter.test(str))
testresults = true
else {
alert("Please input a valid email address!")
testresults = false
}
return (testresults)
}
function checkbae() {
if (document.layers || document.getElementById || document.all)
return checkemail()
else
return true
}
<form name="validation" onSubmit="return checkbae()">
Please input a valid email address:<br />
<input type="text" size=18 name="emailcheck">
<input type="submit" value="Submit">
</form>
Im Gegensatz zu squirtle ist eine komplexe Lösung, aber sie leistet gute Arbeit bei der korrekten Validierung von E-Mails:
function isEmail(email) {
return /^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\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)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))$/i.test(email);
}
So verwenden:
if (isEmail('youremail@yourdomain.com')){ console.log('This is email is valid'); }
Mein Wissen über reguläre Ausdrücke ist nicht so gut. Deshalb überprüfe ich zunächst die allgemeine Syntax mit einem einfachen regulären Ausdruck und prüfe anschließend spezifischere Optionen mit anderen Funktionen. Das ist vielleicht nicht die beste technische Lösung, aber auf diese Weise bin ich viel flexibler und schneller.
Die häufigsten Fehler, auf die ich gestoßen bin, sind Leerzeichen (vor allem am Anfang und Ende) und gelegentlich ein doppelter Punkt.
function check_email(val){
if(!val.match(/\S+@\S+\.\S+/)){ // Jaymon's / Squirtle's solution
// Do something
return false;
}
if( val.indexOf(' ')!=-1 || val.indexOf('..')!=-1){
// Do something
return false;
}
return true;
}
check_email('check@thiscom'); // Returns false
check_email('check@this..com'); // Returns false
check_email(' check@this.com'); // Returns false
check_email('check@this.com'); // Returns true
23 Stimmen
@Alex Der Grund, warum ich diesen Kommentar hinzugefügt habe, ist, dass die vorgeschlagene Regex in der akzeptierten Antwort keine existierenden Live-E-Mail-Adressen zulässt, was ein schlechter Start für einen Kunden ist, und das wirklich große Problem ist, dass selbst WENN die Adresse akzeptiert wurde, sie immer noch nicht sagt, ob sie funktioniert. Die einzige Möglichkeit, zuverlässig zu überprüfen, ob eine angegebene E-Mail eine funktionierende, gültige E-Mail ist, besteht darin, eine E-Mail mit einem Verifizierungslink zu senden. Wenn Ihr Anwendungsfall also keine Verifizierung der E-Mail erfordert, genügt ein minimaler Test auf @, andernfalls sollten Sie eine Verifizierungs-E-Mail verwenden. Regex wird nur eine schlechte Benutzererfahrung bieten.
0 Stimmen
@David Mårtensson Ich habe ein + auf Ihre Gedanken hinzugefügt. Ich denke jedoch, dass eine Verifizierungs-E-Mail-Link-Sache auch eine schlechte Benutzererfahrung sein kann. Eine, die Sie einen Kunden verlieren kann.
7 Stimmen
@mikael1000 Sicher, aber was ist der Zweck einer Regex-Validierung, wenn man sowieso nicht weiß, ob es eine gültige E-Mail ist. Wenn Sie den Kunden nicht mit einem Validierungslink belästigen wollen, machen Sie einfach die einfachste Validierung <irgendwas> bei <irgendwas> und belassen es dabei. Damit stellen Sie sicher, dass der Kunde zumindest etwas eingegeben hat, das eine E-Mail sein könnte, alles andere ist meist Codeverschwendung, bis Sie zur eigentlichen Validierung kommen. Sie könnten möglicherweise überprüfen, ob die Domäne mit einem DNS-Lookup existiert.
0 Stimmen
@DavidMårtensson Wenn ein Kunde in seiner E-Mail ein Zeichen falsch eingibt, wird die E-Mail mit Regexp validiert, wenn sie immer noch falsch ist. Das Ergebnis wird sein: keine Kommunikation möglich. Für mich ist das das schlechteste Benutzererfahrung, die man sich vorstellen kann. Eine Validierungsbestätigung verwickelt den Nutzer in ein Gespräch, das Respekt und echtes Interesse an den Bedürfnissen des Kunden zeigt.
0 Stimmen
Wenn Sie dem Muster von Gmail/Yahoo/Outlook/... folgen wollen, verwenden Sie dies einfacher Regex
2 Stimmen
Sehr ähnlich: Wie kann ich eine E-Mail-Adresse mithilfe eines regulären Ausdrucks überprüfen?
0 Stimmen
Wenn diese Frage offen bleiben soll, muss "Validierung" entfernt werden, andernfalls sollte sie geschlossen werden.
2 Stimmen
Diese Frage wird diskutiert auf meta .
0 Stimmen
@theking2 Ich stimme zu, dass regex nur hilft, das Standard-E-Mail-Format zu überprüfen, aber es wird nicht bestätigen, dass die eingegebene E-Mail-Adresse gültig oder erreichbar ist. Dieses Problem wird von einigen Echtzeit-E-Mail-Validierungstools angegangen. Sie müssen vielleicht prüfen clearout.io/integrationen/echtzeit-javascript-email-validierung . Es hilft sogar, die falsch eingegebene E-Mail-Adresse vorzuschlagen.
0 Stimmen
Ich empfehle, diesen Artikel über die Funktionsweise der E-Mail-Syntax zu lesen: debounce.io/blog/articles/email-syntax-error-explained
0 Stimmen
Ist damit Ihre Frage beantwortet? Wie kann ich eine E-Mail-Adresse mithilfe eines regulären Ausdrucks überprüfen?
3 Stimmen
Ich muss zugeben, dass ich nicht verstehe, warum so viel Validierung betrieben wird, wenn man nicht vorhersagen kann, ob der Benutzer überhaupt einen Basistyp unter Verwendung der gültigen Zeichen erstellt hat. Eine Prüfung auf @ und mindestens einen Punkt reicht am Anfang aus.