我的网站上有一个表单。单击提交按钮时,将运行一个函数以获取每个字段的内容,根据RegEx和其他要求验证内容,然后如果一切正常,则通过Ajax将表单提交给.php邮件程序。
我希望表单在输入字段值更改时自动验证,或者当输入字段失去焦点时(我没有偏好,要么很好)然后我希望表单仅在提交时用户单击表单上的“提交”按钮。如果用户单击“提交”按钮,则在所有字段均有效之前,我不希望表单提交。
这是我的代码:
//contact form validation
$(function(){
$('.error').hide();
// hide error messages onchange
$("#contact-form").change(function(){
$('.error').hide();
$("label#name_error").hide();
$("label#invalid_error").hide();
$("label#email_error").hide();
$("label#invalid_phone_error").hide();
$("label#phone_error").hide();
$("label#zip_error").hide();
});
// validate fields on click
$(".cool-button").click(function(){
$('.error').hide();
$("label#name_error").hide();
$("label#invalid_error").hide();
$("label#email_error").hide();
$("label#invalid_phone_error").hide();
$("label#phone_error").hide();
$("label#zip_error").hide();
var name=$("input#contact_name").val();
var email=$("input#contact_email").val();
var emailRegEx =/^([a-zA-Z0-9])(([a-zA-Z0-9])*([\._-])?([a-zA-Z0-9]))*@(([a-zA-Z0-9\-])+(\.))+([a-zA-Z]{2,4})+$/
var phone=$("input#contact_phone").val();
var phone=phone.replace(/\s+-/g, "");
var phoneRegEx = /^(1-?)?\s?(\([2-9]\d{2}\)|\s?-?[2-9]\d{2})-?\s?[2-9]\d{2}-?\d{4}$/
var zip=$("input#contact_zip").val();
var best_time=$("input#contact_best_time").val();
var message=$("textarea#contact_message").val();
var timestamp=$("input#timestamp").val();
if(name==""){
$("label#name_error").show();
$("input#contact_name").focus();return false;
}
if(email==""){
$("label#email_error").show();
$("input#contact_email").focus();return false;
}
if (document.getElementById('contact_email').value.search(emailRegEx )==-1) {
$("label#invalid_error").show();
$("input#contact_email").focus();return false;
}
if(phone==""){
$("label#phone_error").show();
$("input#contact_phone").focus();return false;
}
if (document.getElementById('contact_phone').value.search(phoneRegEx )==-1) {
$("label#invalid_phone_error").show();
$("input#contact_phone").focus();return false;
}
if(zip==""){
$("label#zip_error").show();
$("input#contact_zip").focus();return false;
}
if(message==""){
$("label#message_error").show();
$("textarea#contact_message").focus();return false;
}
else {
var dataString='contact_name='+name+'&contact_email='+email+'&contact_phone='+phone+'&contact_zip='+zip+'&contact_best_time='+best_time+'×tamp='+timestamp+'&contact_message='+encodeURIComponent(message);
$.ajax({
type:"POST",
url:"php/contact.php",
data:dataString,
success:function(){$('#contact-form').html("<div id='message'></div>");$('#message').html("<h3>Message Sent</h3>").append("<p>Thank you for contacting us. We'll be in touch. <br /><br />If you have any further questions, you can always email us at info@wirecrafters.com or call us at 800-924-9473</p>").hide().fadeIn(800,function(){$('#message').append("<img id='checkmark' src='images/submit2.png' />");});}});
}
return false;
});
});
此处是表格的HTML和PHP代码
<form id="contact-form" method="post" action="#">
<p class="form-subscr-field">
<label for="contact_name" id="contact_name_label">Your name: *</label>
<input id="contact_name" type="text" name="contact_name" class="inputbox" size="10" required/>
<label class="error error-tip" for="contact_name" id="name_error" style="display: none; ">Please enter your name.</label>
</p>
<p class="form-subscr-field">
<label for="contact_email" id="contact_email_label">E-mail Address: *</label>
<input id="contact_email" type="email" name="contact_email" class="inputbox" size="10" required/>
<label class="error error-tip" for="contact_email" id="email_error" style="display: none; ">Please enter your email address.</label>
<label class="error error-tip" for="contact_email" id="invalid_error" style="display: none; ">Invalid email address.</label>
</p>
<fieldset class="w50">
<p class="form-subscr-field rowElem left">
<label for="contact_phone" id="contact_phone_label">Phone: *</label>
<input id="contact_phone" type="tel" name="contact_phone" class="inputbox" size="10" required minlength="9"/>
<label class="error error-tip" for="contact_phone" id="phone_error" style="display: none; ">Please enter your phone number.</label>
<label class="error error-tip" for="contact_phone" id="invalid_phone_error" style="display: none; ">Please enter a valid phone number.</label>
</p>
</fieldset>
<fieldset class="w50">
<p class="form-subscr-field rowElem right">
<label for="contact_zip" id="contact_zip_label">Zip Code: *</label>
<input id="contact_zip" type="text" name="contact_zip" class="inputbox" size="10" required minlength="5"/>
<label class="error error-tip" for="contact_zip" id="zip_error" style="display: none; ">Please enter your shipping zip code.</label>
</p>
</fieldset>
<p class="form-subscr-field">
<label for="contact_best_time" id="contact_best_time_label">Best time to Contact:</label>
<input id="contact_best_time" type="text" name="contact_best_time" class="inputbox" size="10" />
</p>
<p class="form-subscr-field">
<label for="contact_message" id="comment_label">Your message: *</label>
<textarea id="contact_message" name="contact_message" rows="8" cols="30" required minlength="2"></textarea>
<label class="error error-tip" for="contact_message" id="message_error" style="display: none; ">This field is required.</label>
</p>
<input type="hidden" id="timestamp" name="timestamp" value="<?php
$hourdiff = "2"; // hours diff btwn server and local time
$insertdate = date("l, d F Y h:i a",time() + ($hourdiff * 3600));
print ("$insertdate");
?>" />
<div class="submit-contact">
<p>
<input type="submit" name="submit" class="cool-button csbutton-color spot-action" id="contact_button" value="Submit" />
</p>
</div>
</form>
答案 0 :(得分:0)
你应该使用某种验证器插件。就个人而言,我已经使用了jquery工具形式验证器,它的工作效果很好..还有其他工具。检查一下: http://flowplayer.org/tools/validator/
我还使用了一个我建立的插件,它将采用一个表单并通过ajax提交它,并且有一些工作真正类似于我的工作:
http://jquery.malsup.com/form/
是一个例子。这允许您在普通的html中创建表单,它将表单提交到表单的操作URL,并且它将构建表单值,就像浏览器在没有ajax的情况下提交的那样。因此,无论你的后端脚本是什么,表单字段就像你没有使用ajax一样提交。
因为这对你来说似乎太多了,所以让我告诉你代码在没有它的情况下的样子。
没有(看看你的js)。
不,假设您的表单看起来像这样(简化)
<form method="POST" action="php/contact.php">
<label for="contact_name">Name</label>
<input name="contact_name" id="contact_name" />
<br />
<label for="contact_email">Email</label>
<input name="contact_email" id="contact_email" />
<br />
<label for="contact_phone">Phone</label>
<input name="contact_phone" id="contact_phone" />
<br />
<label for="contact_zip">Zip</label>
<input name="contact_zip" id="contact_zip" />
<br />
<label for="contact_best_time">Best time for Contact</label>
<input name="contact_best_time" id="contact_best_time" />
<br />
<label for="contact_message">Message:</label>
<input name="contact_message" id="contact_message" />
</form>
现在这可能与现在看起来类似,没有用于格式化的所有额外html。
如果同时使用了验证器和ajax表单验证器,则必须进行任何更改。让我告诉他们。
使用验证器和ajax表单,您将拥有:
<form method="POST" action="php/contact.php" class="use-validator ajax-form">
<label for="contact_name">Name</label>
<input name="contact_name" id="contact_name" />
<br />
<label for="contact_email">Email</label>
<input name="contact_email" id="contact_email" type="email" required="required" />
<br />
<label for="contact_phone">Phone</label>
<input name="contact_phone" id="contact_phone" type="phone" />
<br />
<label for="contact_zip">Zip</label>
<input name="contact_zip" id="contact_zip" required="required" />
<br />
<label for="contact_best_time">Best time for Contact</label>
<input name="contact_best_time" id="contact_best_time" required="required" />
<br />
<label for="contact_message">Message:</label>
<textarea name="contact_message" id="contact_message" required="required"></textarea>
</form>
然后你的js将是:
$.tools.validator.fn("[type=phone]", "Invalid phone number", function(input, value) {
var phoneRegEx = /^(1-?)?\s?(\([2-9]\d{2}\)|\s?-?[2-9]\d{2})-?\s?[2-9]\d{2}-?\d{4}$/
return value.test(phoneRegEx);
});
$("form.use-validator").validator();
$("form.ajax-form").ajaxForm({
success:function(){$('#contact-form').html("<div id='message'></div>");$('#message').html("<h3>Message Sent</h3>").append("<p>Thank you for contacting us. We'll be in touch. <br /><br />If you have any further questions, you can always email us at info@wirecrafters.com or call us at 800-924-9473</p>").hide().fadeIn(800,function(){$('#message').append("<img id='checkmark' src='images/submit2.png' />");});}});
});
您制作的任何自定义验证器都可以在其他表单上重复使用..
然后您可能需要一些自定义错误消息,但就是这样..您可以删除所有其他js代码。
答案 1 :(得分:0)
这通常通过keyup
函数实现。
每当释放一个键时,可以调用一个函数来确保所有字段都是准确的,如果是,则以不引人注目的方式让用户知道。在您的情况下,您可以禁用提交按钮,除非所有字段都正确。
注意:您永远不应该使用该功能修改当前编辑的文本字段,或者做任何其他会对用户造成烦扰的事情;)
编辑:我修改了代码以在每次为所有输入字段解除密钥时进行验证。 我不熟悉JQuery,所以我用vanilla Javascript做到了。如果需要,它应该很容易转换。
$(function(){
var inputs = document.getElementsByTagName("input");
for(var i = 0; i < inputs.length; i++) {
inputs[i].addEventListener("keyup", function(){validate()}, true);
}
$('.error').hide();
$(".cool-button").click(function(){validate()});
function validate() {
$('.error').hide();
$("label#name_error").hide();
$("label#invalid_error").hide();
$("label#email_error").hide();
$("label#invalid_phone_error").hide();
$("label#phone_error").hide();
$("label#zip_error").hide();
var name=$("input#contact_name").val();
var email=$("input#contact_email").val();
var emailRegEx =/^([a-zA-Z0-9])(([a-zA-Z0-9])*([\._-])?([a-zA-Z0-9]))*@(([a-zA-Z0-9\-])+(\.))+([a-zA-Z]{2,4})+$/
var phone=$("input#contact_phone").val();
var phone=phone.replace(/\s+-/g, "");
var phoneRegEx = /^(1-?)?\s?(\([2-9]\d{2}\)|\s?-?[2-9]\d{2})-?\s?[2-9]\d{2}-?\d{4}$/
var zip=$("input#contact_zip").val();
var best_time=$("input#contact_best_time").val();
var message=$("textarea#contact_message").val();
var timestamp=$("input#timestamp").val();
if(name==""){
$("label#name_error").show();$("input#contact_name").focus();return false;
}
if(email==""){
$("label#email_error").show();$("input#contact_email").focus();return false;
}
if (document.getElementById('contact_email').value.search(emailRegEx )==-1) {
$("label#invalid_error").show();$("input#contact_email").focus();return false;
}
if(phone==""){
$("label#phone_error").show();$("input#contact_phone").focus();return false;
}
if (document.getElementById('contact_phone').value.search(phoneRegEx )==-1) {
$("label#invalid_phone_error").show();$("input#contact_phone").focus();return false;
}
if(zip==""){
$("label#zip_error").show();$("input#contact_zip").focus();return false;
}
if(message==""){
$("label#message_error").show();$("textarea#contact_message").focus();return false;
}
else {
var dataString='contact_name='+name+'&contact_email='+email+'&contact_phone='+phone+'&contact_best_time='+best_time+'&contact_zip='+zip+'×tamp='+timestamp+'&contact_message='+encodeURIComponent(message);
$.ajax({
type:"POST",
url:"php/contact.php",
data:dataString,
success:function(){$('#contact-form').html("<div id='message'></div>");$('#message').html("<h3>Message Sent</h3>").append("<p>Thank you for contacting us. We'll be in touch. <br /><br />If you have any further questions, you can always email us at info@wirecrafters.com or call us at 800-924-9473</p>").hide().fadeIn(800,function(){$('#message').append("<img id='checkmark' src='images/submit2.png' />");});}});
}
return false;
};
});
答案 2 :(得分:0)
我倾向于为每个输入打破验证,这使得这些东西变得更容易。你也可以使用一个jQuery插件,从长远来看可能更加模块化。
那就是说,我会这样做(working jsFiddle):
//contact form validation
$(function() {
$('.error').hide(); //hide all errors
function fieldHasValue(field, label) {
var value = field.val().trim(); //Grab value without leading or trailing whitespace
if (value.length > 0) {
label.hide();
} else {
label.show();
field.focus();
}
return (value.length > 0);
}
function nameIsValid() {
return fieldHasValue($("input#contact_name"), $("label#name_error"));
}
function emailIsValid() {
var email = $("input#contact_email").val().trim(); //Grab value without leading or trailing whitespace
var emailRegEx = /^([a-zA-Z0-9])(([a-zA-Z0-9])*([\._\-])?([a-zA-Z0-9]))*@(([a-zA-Z0-9\-])+(\.))+([a-zA-Z]{2,4})+$/;
var isValid = (email.length > 0) && email.match(emailRegEx);
if (isValid) {
$("label#email_error").hide();
$("label#invalid_error").hide();
} else if (email.length > 0) {
$("label#invalid_error").show();
$("input#contact_email").focus();
} else {
$("label#email_error").show();
$("input#contact_email").focus();
}
return isValid;
}
function phoneIsValid() {
var phone = $("input#contact_phone").val().replace(/\s+-/g, "").trim(); //Grab value without leading or trailing whitespace and replace [whitespace -] with an empty string.
var phoneRegEx = /^(1-?)?\s?(\([2-9]\d{2}\)|\s?-?[2-9]\d{2})-?\s?[2-9]\d{2}-?\d{4}$/;
var isValid = (phone.length > 0) && phone.match(phoneRegEx);
if (isValid) {
$("label#invalid_phone_error").hide();
$("label#phone_error").hide();
} else if (phone.length > 0) {
$("label#invalid_phone_error").show();
$("input#contact_phone").focus();
} else {
$("label#phone_error").show();
$("input#contact_phone").focus();
}
return isValid;
}
function zipIsValid() {
return fieldHasValue($("input#contact_zip"), $("label#zip_error"));
}
function messageIsValid() {
return fieldHasValue($("textarea#contact_message"), $("label#message_error"));
}
function bestTimeIsValid() {
return fieldHasValue($("input#contact_best_time"), $("label#best_time_error"));
}
function allInputsAreValid() {
var validName = nameIsValid();
var validEmail = emailIsValid();
var validPhone = phoneIsValid();
var validZIP = zipIsValid();
var validMessage = messageIsValid();
var validBestTime = bestTimeIsValid();
var isValid = validName && validEmail && validPhone && validZIP && validMessage && validBestTime;
return isValid;
}
$("input#contact_name").on('change blur', nameIsValid);
$("input#contact_email").on('change blur', emailIsValid);
$("input#contact_phone").on('change blur', phoneIsValid);
$("input#contact_zip").on('change blur', zipIsValid);
$("textarea#contact_message").on('change blur', messageIsValid);
$("input#contact_best_time").on('change blur', bestTimeIsValid);
$("input#contact_button").on('click', function (e) {
var timestamp = $("input#timestamp").val();
if (allInputsAreValid()) {
var dataString = 'contact_name=' + name + '&contact_email=' + email + '&contact_phone=' + phone + '&contact_zip=' + zip + '&contact_best_time=' + best_time + '×tamp=' + timestamp + '&contact_message=' + encodeURIComponent(message);
$.ajax({
type: "POST",
url: "php/contact.php",
data: dataString,
success: function() {
$('#contact-form').html("<div id='message'></div>");
$('#message').html("<h3>Message Sent</h3>").append("<p>Thank you for contacting us. We'll be in touch. <br /><br />If you have any further questions, you can always email us at info@wirecrafters.com or call us at 800-924-9473</p>").hide().fadeIn(800, function() {
$('#message').append("<img id='checkmark' src='images/submit2.png' />");
});
}
});
}
e.preventDefault();
return false;
});
});