一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

番茄的表單驗證類代碼修改版

在經典論壇上發過一次,個人的項目中在后臺處理時用到這個東西,對于簡單的表單驗證還是挺方便的。
因為不想讓代碼變得太臃腫,所以有很多不常用的功能就沒有再添加了
對于我佛山人的意見就沒有做修改了,為什么?因為我懶唄,哈哈
今天看到omeweb也修改了一個版本,做了許多修改,改得挺不錯的,謝謝了。

源碼在這里: 

//去除字符串兩邊的空格
String.prototype.trim = function () {
    return this.replace(/(^/s+)|(/s+$)/g, "");
}
//檢測字符串是否為空
String.prototype.isEmpty = function () {
    return !(/.?[^/s ]+/.test(this));
}
//檢測值是否介于某兩個指定的值之間
String.prototype.isBetween = function (val, min, max) {
    return isNaN(val) == false && val >= min && val <= max;
}
//獲取最大值或最小值
String.prototype.getBetweenVal = function (what) {
    var val = this.split(',');
    var min = val[0];
    var max = val[1] == null ? val[0] : val[1];
    if (parseInt(min) > parseInt(max)) {
        min = max;
        max = val[0];
    }
    return what == 'min' ? (isNaN(min) ? null : min) : (isNaN(max) ? null : max);
}
var validator = function (formObj) {
    this.allTags = formObj.getElementsByTagName('*');
    //字符串驗證正則表達式
    this.reg = new Object();
    this.reg.english = /^[a-zA-Z0-9_/-]+$/;
    this.reg.chinese = /^[/u0391-/uFFE5]+$/;
    this.reg.number = /^[-/+]?/d+(/./d+)?$/;
    this.reg.integer = /^[-/+]?/d+$/;
    this.reg.float = /^[-/+]?/d+(/./d+)?$/;
    this.reg.date = /^(/d{4})(-|//)(/d{1,2})/2(/d{1,2})$/;
    this.reg.email = /^/w+([-+.]/w+)*@/w+([-.]/w+)*/./w+([-.]/w+)*$/;
    this.reg.url = /^(((ht|f)tp(s?))/:////)[a-zA-Z0-9]+/.[a-zA-Z0-9]+[//=/?%/-&_~`@[/]
/':+!]*([^<>/"/"])*$/;
    this.reg.phone = /^((/(/d{2,3}/))|(/d{3}/-))?(/(0/d{2,3}/)|0/d{2,3}-)?[1-9]/d{6,7}(/-/d
{1,4})?$/;
    this.reg.mobile = /^((/(/d{2,3}/))|(/d{3}/-))?((13/d{9})|(159/d{8}))$/;
    this.reg.ip = /^(0|[1-9]/d?|[0-1]/d{2}|2[0-4]/d|25[0-5]).(0|[1-9]/d?|[0-1]/d{2}|2[0-4]
/d|25[0-5]).(0|[1-9]/d?|[0-1]/d{2}|2[0-4]/d|25[0-5]).(0|[1-9]/d?|[0-1]/d{2}|2[0-4]/d|25[0-
5])$/;
    this.reg.zipcode = /^[1-9]/d{5}$/;
    this.reg.qq = /^[1-9]/d{4,10}$/;
    this.reg.msn = /^/w+([-+.]/w+)*@/w+([-.]/w+)*/./w+([-.]/w+)*$/;
    this.reg.idcard = /(^/d{15}$)|(^/d{17}[0-9Xx]$)/;
    //錯誤輸出信息
    this.tip = new Object();
    this.tip.unknow = '未找到的驗證類型,無法執行驗證。';
    this.tip.paramError = '參數設置錯誤,無法執行驗證。';
    this.tip.required = '不允許為空。';
    this.tip.english = '僅允許英文字符及下劃線 (a-zA-Z0-9_)。';
    this.tip.chinese = '僅允許中文字符。';
    this.tip.number = '不是一個有效的數字。';
    this.tip.integer = '不是一個有效的整數。';
    this.tip.float = '不是一個有效的浮點數。';
    this.tip.date = '不是一個有效的日期格式。 (例如:2007-06-29)';
    this.tip.email = '不是一個有效的電子郵件格式。';
    this.tip.url = '不是一個有效的超鏈接格式。';
    this.tip.phone = '不是一個有效的電話號碼。';
    this.tip.mobile = '不是一個有效的手機號碼。';
    this.tip.ip = '不是一個有效的IP地址。';
    this.tip.zipcode = '不是一個有效的郵政編碼。';
    this.tip.qq = '不是一個有效的QQ號碼。';
    this.tip.msn = '不是一個有效的MSN帳戶。';
    this.tip.idcard = '不是一個有效的身份證號碼。';
    //獲取控件名稱
    this.getControlName = function ()
    {
        return this.element.getAttribute('controlName') == null
               ? '指定控件的值'
               : this.element.getAttribute('controlName');
    }
    //設定焦點
    this.setFocus = function (ele) {
        try {
            ele.focus();
        } catch (e){}
    }
    //設置邊框顏色
    this.setBorderColor = function (ele) {
        var borderColor = ele.currentStyle ?
                          ele.currentStyle.borderColor :
                          document.defaultView.getComputedStyle(ele, null)['borderColor'];
        ele.style.borderColor = '#ff9900';
        ele.onkeyup = function () {
            this.style.borderColor = borderColor;
        }
    }
    //輸出錯誤反饋信息
    this.feedback = function (type) {
        try {
            var msg = eval('this.tip.' + type) == undefined ?
                      type :
                      this.getControlName() + eval('this.tip.' + type);
        } catch (e) {
            msg = type;
        }
        this.setBorderColor(this.element);
        alert(msg);
        this.setFocus(this.element);
    };
    //執行字符串驗證
    this.validate = function () {
        var v = this.element.value;
        //驗證是否允許非空
        var required = this.element.getAttribute('required');
        if (required != null && v.isEmpty()) {
            this.feedback('required');
            return false;
        }
        //驗證是否合法格式
        var dataType = this.element.getAttribute('dataType');
        if (!v.isEmpty() && dataType != null &&  dataType.toLowerCase() != 'password') {
            dataType = dataType.toLowerCase();
            try {
                if (!(eval('this.reg.' + dataType)).test(v)) {
                    this.feedback(dataType);
                    return false;
                }
            } catch(e) {
                this.feedback('unknow');
                return false;
            }
        }
        //執行數據驗證
        var confirm = this.element.getAttribute('confirm');
        if (confirm != null) {
            try {
                var data = eval('formObj.' + confirm + '.value');
                if (v != data) {
                    alert('兩次輸入的內容不一致,請重新輸入。');
                    this.setBorderColor(this.element);
                    this.setFocus(this.element);
                    return false;
                }
            } catch (e) {
                this.feedback('paramError');
                return false;
            }
        }
        //驗證數字大小
        var dataBetween = this.element.getAttribute('dataBetween');
        if (!v.isEmpty() && dataBetween != null) {
            var min = dataBetween.getBetweenVal('min');
            var max = dataBetween.getBetweenVal('max');
            if (min == null || max == null) {
                this.feedback('paramError');
                return false;
            }
            if (!v.isBetween(v.trim(), min, max)) {
                this.feedback(this.getControlName() + '必須是介于 ' + min + '-' + max + ' 之
間的數字。');
                return false;
            }
        }
        //驗證字符長度
        var dataLength = this.element.getAttribute('dataLength');
        if (!v.isEmpty() && dataLength != null) {
            var min = dataLength.getBetweenVal('min');
            var max = dataLength.getBetweenVal('max');
            if (min == null || max == null) {
                this.feedback('paramError');
                return false;
            }
            if (!v.isBetween(v.trim().length, min, max)) {
                this.feedback(this.getControlName() + '必須是 ' + min + '-' + max + ' 個字符
。');
                return false;
            }
        }
        return true;
    };
    //執行初始化操作
    this.init = function () {
        for (var i=0; i<this.allTags.length; i++) {
            if (this.allTags[i].tagName.toUpperCase() == 'INPUT' ||
                this.allTags[i].tagName.toUpperCase() == 'SELECT' ||
                this.allTags[i].tagName.toUpperCase() == 'TEXTAREA')
            {
                this.element = allTags[i];
                if (!this.validate())
                    return false;
            }
        }
    };
    return this.init();
}

JavaScript技術番茄的表單驗證類代碼修改版,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 涩涩涩在线视频 | 中文字幕一区中文亚洲 | 2021最新国产成人精品免费 | 五月sese | 精品午夜久久福利大片免费 | 欧美一区二区三区视频 | 国产欧美激情一区二区三区-老狼 | 成人免费看片视频色多多 | 人和拘一级毛片 | 国产在线观看成人 | 国产成人精品一区二区三区 | 怡红院官网 | 久久久久久网站 | 国产午夜视频在线观看网站 | 最新在线观看精品国产福利片 | www亚洲一区 | 激情一区二区三区成人 | 欧美日韩一区视频 | 久996视频精品免费观看 | 久久瑟 | 国产精品福利一区二区 | 麻豆播放 | 欧美激情区 | 日韩三级一区二区 | 日本不卡一区二区三区四区 | 国产成人综合久久精品亚洲 | 九九99九九精彩网站 | 五月婷六月婷婷 | 伊人国产在线播放 | 乱人伦一区二区三区 | 久久国产成人精品国产成人亚洲 | 久久久久777777人人人视频 | 欧美激情a∨在线视频播放 欧美激情不卡 | 美女黄板视频 | 亚洲一区二区三 | 久久er精品热线免费 | 亚洲综合啪啪 | 色哟哟精品 | 午夜黄色福利 | 欧美激情亚洲 | 中文字幕在线有码 |