Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/439.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 每个表单的通用表单验证程序_Javascript_Html_Class_Javascript Objects - Fatal编程技术网

Javascript 每个表单的通用表单验证程序

Javascript 每个表单的通用表单验证程序,javascript,html,class,javascript-objects,Javascript,Html,Class,Javascript Objects,我在不同的页面上有多个表单,这些表单都有公共字段(例如电子邮件),所以我想创建一个通用类/函数,用不同的字段验证不同的表单,顺便说一句,我对javascript没有太多经验 以下是原始验证程序在函数形式中的外观: function validateform(form) { $(".req").css("border","1px solid green"); $(".email").css("

我在不同的页面上有多个表单,这些表单都有公共字段(例如电子邮件),所以我想创建一个通用类/函数,用不同的字段验证不同的表单,顺便说一句,我对javascript没有太多经验

以下是原始验证程序在函数形式中的外观:

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;
        }
    }

}