天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

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

在經典論壇上發過一次,個人的項目中在后臺處理時用到這個東西,對于簡單的表單驗證還是挺方便的。
因為不想讓代碼變得太臃腫,所以有很多不常用的功能就沒有再添加了
對于我佛山人的意見就沒有做修改了,為什么?因為我懶唄,哈哈
今天看到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技術番茄的表單驗證類代碼修改版,轉載需保留來源!

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

主站蜘蛛池模板: 大胸美女被cao哭 | 泡妞高手在都市完整版视频免费 | 99九九99九九九视频精品 | 国产精品无码人妻99999 | 首页_亚洲AV色老汉影院 | 护士日本xx厕所 | 国产精品高清视亚洲一区二区 | 国产精品1卡二卡三卡四卡乱码 | 五月丁香啪啪. | 囯产愉拍亚洲精品一区 | 精品国产乱码久久久久久免费流畅 | 国产91专区 | 99久久精品一区二区三区 | 亚洲精品国产精品精 | 欧美日韩一区不卡在线观看 | 国产精品毛片AV久久97 | 伊人亚洲AV久久无码精品 | 97精品视频 | 短篇合集纯肉高H深陷骚 | 99re久久热免费视频 | 午夜向日葵视频在线观看 | 艳妇臀荡乳欲伦岳TXT下载 | 国产电影三级午夜a影院 | 一区二区三区国产亚洲网站 | 成人高清网站 | CHINA篮球体育飞机2023 | 免费看男人J放进女人J无遮掩 | 伊人精品影院一本到综合 | 性欧美videos俄罗斯 | YELLOW免费观看完整视频 | 丰满五十六十老熟女HD60 | 国产日韩久久久精品影院首页 | 添加一点爱与你电视剧免费观看 | 乳欲性高清在线 | 国产亚洲精品久久久久久久 | 大学生高潮无套内谢视频 | 高h 纯肉文 | 嫩草影院地址一地址二 | 凹凸精品视频分类视频 | 乱精品一区字幕二区 | 亚洲欧美强伦一区二区另类 |