laurence keith albano laurence keith albano - 1 year ago 94
HTML Question

Validate an email and display message inside a span tag

I have this simple code here about the input type email. I have some reference about validating an email when user clicks the button. Here's the reference

HTML code

<div class="form-group">
<input class="form-control" placeholder="Email" name="email" id="email" type="email" required>
<span id="checkEmail"></span>
<script src=""></script>
<script src=""></script>
<script src="" type="text/javascript"></script>

I tried the script to validate and display a message in the span tag id="checkEmail" using keyup event function but it doesn't seem to work. Does my syntax is incorrect? Please help.

Its Script

//Email Regular Expression function
function validateEmail(email) {
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(email);

//Email Validate function
function validate() {
$("#email").keyup(function() {

var email = $("#email").val();
if (validateEmail(email)) {
$("#checkEmail").text(email + " is valid :)");
$("#checkEmail").css("color", "green");
} else {
$("#checkEmail").text(email + " is not valid :(");
$("#checkEmail").css("color", "red");

$(document).ready(function() {

Answer Source

Your code works for me, all I needed to do is to call


anywhere on document load to actually bind the events.

(which means you might want to move the binding outside the validate function, to not re-bind it anytime you click/use the function)

edit: I have prepared a fiddle for you:

Recommended from our users: Dynamic Network Monitoring from WhatsUp Gold from IPSwitch. Free Download