Javascript 每个表单的通用表单验证程序
我在不同的页面上有多个表单,这些表单都有公共字段(例如电子邮件),所以我想创建一个通用类/函数,用不同的字段验证不同的表单,顺便说一句,我对javascript没有太多经验 以下是原始验证程序在函数形式中的外观:Javascript 每个表单的通用表单验证程序,javascript,html,class,javascript-objects,Javascript,Html,Class,Javascript Objects,我在不同的页面上有多个表单,这些表单都有公共字段(例如电子邮件),所以我想创建一个通用类/函数,用不同的字段验证不同的表单,顺便说一句,我对javascript没有太多经验 以下是原始验证程序在函数形式中的外观: function validateform(form) { $(".req").css("border","1px solid green"); $(".email").css("
function validateform(form) {
$(".req").css("border","1px solid green");
$(".email").css("border","1px solid green");
$(".docs-file").css("border","1px solid green");
$(".images-file").css("border","1px solid green");
$(".req").each(function() {
if($(this).val() == "" || $(this).val().replace(/\s/g, '').length == 0) {
$(this).css("border","1px solid red");
return false;
}
});
if((/^\w+([\.-]?\w+)*@\w+([\.-]?\w+)*(\.\w{2,3})+$/.test($(".email").val())))
{}
else {
$(".email").css("border","1px solid red");
return false;
}
var doc_file = $(".doc-file").val().split(/(\\|\/)/g).pop()
var docs_re = /(\.pdf|\.doc|\.docx|\.pptx|\.xlsx|\.xls)$/i;
if (!docs_re.exec(doc_file)) {
$(".docs-file").css("border","1px solid red");
return false;
}
var image_file = $(".image-file").val().split(/(\\|\/)/g).pop()
var image_re = /(\.jpg|\.jpeg|\.bmp|\.gif|\.png)$/i;
if (!image_re.exec(image_file) || $(".image-file").val() == '') {
$(".images-file").css("border","1px solid red");
return false;
}
var pwd1 = $('[name=password1]');
var pwd2 = $('[name=password2]');
var pwdre = /(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,}/;
if (!pwdre.exec(pwd1)){
pwd1.css("border","1px solid red");
return false;
}
if (pwd1.val() == pwd2.val()){
} else {
pwd2.css("border","1px solid red");
return false;
}
return True;
}
并不是所有表单都共享相同的字段,我对基于字符的字段(如name/username/textareas)进行了req,但问题是将此函数放在所有表单中会返回错误,例如,对于没有密码字段的表单
我的问题是,如果我将其制作成一个类,如果这是图像,我应该如何以不同的形式调用不同的方法:
class FormValidator{
email_validor(email){
if((/^\w+([\.-]?\w+)*@\w+([\.-]?\w+)*(\.\w{2,3})+$/.test(email.val())))
{}
else {
email.css("border","1px solid red");
console.log('email error');
return false;
}
}
}