Verwendung von reguläre Ausdrücke ist wahrscheinlich der beste Weg. Sie können eine Reihe von Tests sehen aquí (entnommen aus Chrom )
const validateEmail = (email) => {
return String(email)
.toLowerCase()
.match(
/^(([^<>()[\]\\.,;:\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,}))$/
);
};
Hier ist ein Beispiel für einen regulären Ausdruck, der Unicode akzeptiert:
const re =
/^(([^<>()[\]\.,;:\s@\"]+(\.[^<>()[\]\.,;:\s@\"]+)*)|(\".+\"))@(([^<>()[\]\.,;:\s@\"]+\.)+[^<>()[\]\.,;:\s@\"]{2,})$/i;
Denken Sie aber daran, dass Sie sich nicht nur auf die JavaScript-Validierung verlassen sollten. JavaScript kann leicht deaktiviert werden. Dies sollte auch auf der Serverseite validiert werden.
Hier ist ein Beispiel für die oben beschriebene Vorgehensweise:
const validateEmail = (email) => {
return email.match(
/^(([^<>()[\]\\.,;:\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,}))$/
);
};
const validate = () => {
const $result = $('#result');
const email = $('#email').val();
$result.text('');
if (validateEmail(email)) {
$result.text(email + ' is valid :)');
$result.css('color', 'green');
} else {
$result.text(email + ' is not valid :(');
$result.css('color', 'red');
}
return false;
}
$('#email').on('input', validate);
Und das ist die html
:
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<label for="email">Enter an email address: </label>
<input id="email" />
<h2 id="result"></h2>
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.