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

番茄的表單驗(yàn)證類代碼修改版

在經(jīng)典論壇上發(fā)過一次,個(gè)人的項(xiàng)目中在后臺處理時(shí)用到這個(gè)東西,對于簡單的表單驗(yàn)證還是挺方便的。
因?yàn)椴幌胱尨a變得太臃腫,所以有很多不常用的功能就沒有再添加了
對于我佛山人的意見就沒有做修改了,為什么?因?yàn)槲覒袉h,哈哈
今天看到omeweb也修改了一個(gè)版本,做了許多修改,改得挺不錯(cuò)的,謝謝了。

源碼在這里: 

//去除字符串兩邊的空格
String.prototype.trim = function () {
    return this.replace(/(^/s+)|(/s+$)/g, "");
}
//檢測字符串是否為空
String.prototype.isEmpty = function () {
    return !(/.?[^/s ]+/.test(this));
}
//檢測值是否介于某兩個(gè)指定的值之間
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('*');
    //字符串驗(yàn)證正則表達(dá)式
    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]$)/;
    //錯(cuò)誤輸出信息
    this.tip = new Object();
    this.tip.unknow = '未找到的驗(yàn)證類型,無法執(zhí)行驗(yàn)證。';
    this.tip.paramError = '參數(shù)設(shè)置錯(cuò)誤,無法執(zhí)行驗(yàn)證。';
    this.tip.required = '不允許為空。';
    this.tip.english = '僅允許英文字符及下劃線 (a-zA-Z0-9_)。';
    this.tip.chinese = '僅允許中文字符。';
    this.tip.number = '不是一個(gè)有效的數(shù)字。';
    this.tip.integer = '不是一個(gè)有效的整數(shù)。';
    this.tip.float = '不是一個(gè)有效的浮點(diǎn)數(shù)。';
    this.tip.date = '不是一個(gè)有效的日期格式。 (例如:2007-06-29)';
    this.tip.email = '不是一個(gè)有效的電子郵件格式。';
    this.tip.url = '不是一個(gè)有效的超鏈接格式。';
    this.tip.phone = '不是一個(gè)有效的電話號碼。';
    this.tip.mobile = '不是一個(gè)有效的手機(jī)號碼。';
    this.tip.ip = '不是一個(gè)有效的IP地址。';
    this.tip.zipcode = '不是一個(gè)有效的郵政編碼。';
    this.tip.qq = '不是一個(gè)有效的QQ號碼。';
    this.tip.msn = '不是一個(gè)有效的MSN帳戶。';
    this.tip.idcard = '不是一個(gè)有效的身份證號碼。';
    //獲取控件名稱
    this.getControlName = function ()
    {
        return this.element.getAttribute('controlName') == null
               ? '指定控件的值'
               : this.element.getAttribute('controlName');
    }
    //設(shè)定焦點(diǎn)
    this.setFocus = function (ele) {
        try {
            ele.focus();
        } catch (e){}
    }
    //設(shè)置邊框顏色
    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;
        }
    }
    //輸出錯(cuò)誤反饋信息
    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);
    };
    //執(zhí)行字符串驗(yàn)證
    this.validate = function () {
        var v = this.element.value;
        //驗(yàn)證是否允許非空
        var required = this.element.getAttribute('required');
        if (required != null && v.isEmpty()) {
            this.feedback('required');
            return false;
        }
        //驗(yàn)證是否合法格式
        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;
            }
        }
        //執(zhí)行數(shù)據(jù)驗(yàn)證
        var confirm = this.element.getAttribute('confirm');
        if (confirm != null) {
            try {
                var data = eval('formObj.' + confirm + '.value');
                if (v != data) {
                    alert('兩次輸入的內(nèi)容不一致,請重新輸入。');
                    this.setBorderColor(this.element);
                    this.setFocus(this.element);
                    return false;
                }
            } catch (e) {
                this.feedback('paramError');
                return false;
            }
        }
        //驗(yàn)證數(shù)字大小
        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 + ' 之
間的數(shù)字。');
                return false;
            }
        }
        //驗(yàn)證字符長度
        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 + ' 個(gè)字符
。');
                return false;
            }
        }
        return true;
    };
    //執(zhí)行初始化操作
    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技術(shù)番茄的表單驗(yàn)證類代碼修改版,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 51无码人妻精品1国产 | 国产偷国产偷亚洲高清SWAG | 甜性涩爱全集在线观看 | 欧美亚洲日韩国产在线在线 | 久久精品男人影院 | 精品欧美小视频在线观看 | 日本红怡院亚洲红怡院最新 | 日韩亚洲欧美中文在线 | 国产日韩欧美三级 | 亚洲成熟人网站 | 青青草原免费在线 | 亚洲日韩中文字幕区 | 最近中文字幕MV免费看 | 午夜AV内射一区二区三区红桃视 | 高H各种PLAY全肉NP | 一品道门免费视频韩国 | 亚洲国产日韩a精品乱码 | 香蕉水蜜桃牛奶涩涩 | 天天综合网网欲色 | 欧美丰满少妇久久无码精品 | 男人插曲女人下生免费大全 | 精品国产精品人妻久久无码五月天 | 国产乱子影视频上线免费观看 | 日韩欧美一区二区三区免费观看 | 日本真人啪啪试看30秒 | 久久久午夜精品福利内容 | 女人把腿张开叫男人桶免费视频 | 被爽到叫呻呤视频免费视频 | 亚洲国产日韩欧美在线a乱码 | 在线免费国产 | 精品香蕉99久久久久网站 | 丰满少妇69激懒啪啪无码 | 全黄H全肉细节文短篇 | 国产成人免费观看 | 久久国产精品永久免费网站 | 一本久道久久综合婷婷五月 | 国产亚洲视频精彩在线播放 | 少女亚洲free | black大战chinese周晓琳 | 最新高清无码专区在线视频 | 丝袜美女被艹 |