现在的位置: 首页 > easyui > Form > validatebox > 正文
validatebox组件常用校验规则搜集整理
2012年06月25日 validatebox ⁄ 共 4009字 评论数 3 ⁄ 被围观 6,676 views+

个人觉得easyui的validatebox组件是非常小巧的插件了,扩展方式较为灵活,一些常用的规则,网络上早就一堆大人给出来了,本文是从网上搜集的一些常用校验规则,以供大家参考,所有规则我都亲自验证过,请大家放心使用。

$.extend($.fn.validatebox.defaults.rules, {
	alpha:{
        validator:function(value,param){
            if (value){
                return /^[a-zA-Z\u00A1-\uFFFF]*$/.test(value);   
            } else {
                return true;
            }
        },
        message:'只能输入字母.'   
    },
    alphanum:{
        validator:function(value,param){
            if (value){
                return /^([a-zA-Z\u00A1-\uFFFF0-9])*$/.test(value);   
            } else {
                return true;
            }
        },   
        message:'只能输入字母和数字.'   
    },   
    positiveInt:{
        validator:function(value,param){
            if (value){
                return /^[0-9]*[1-9][0-9]*$/.test(value);   
            } else {
                return true;
            }
        },   
        message:'只能输入正整数.'   
    },  
    chsNoSymbol:{
        validator:function(value,param){
            return /^[\u4E00-\u9FA5]+$/.test(value);   
    	},
		message:'只能输入中文'
	},
    chs: {
        validator: function (value, param) {
            return /^[\u0391-\uFFE5]+$/.test(value);
        },
        message: '请输入汉字'
    },
    zip: {
        validator: function (value, param) {
            return /^[1-9]\d{5}$/.test(value);
        },
        message: '邮政编码不存在'
    },
    qq: {
        validator: function (value, param) {
            return /^[1-9]\d{4,10}$/.test(value);
        },
        message: 'QQ号码不正确'
    },
    mobile: {
        validator: function (value, param) {
            return /^((\(\d{2,3}\))|(\d{3}\-))?13\d{9}$/.test(value);
        },
        message: '手机号码不正确'
    },
    loginName: {
        validator: function (value, param) {
            return /^[\u0391-\uFFE5\w]+$/.test(value);
        },
        message: '登录名称只允许汉字、英文字母、数字及下划线。'
    },
    safepass: {
        validator: function (value, param) {
            return safePassword(value);
        },
        message: '密码由字母和数字组成,至少6位'
    },
    equalTo: {
        validator: function (value, param) {
            return value == $(param[0]).val();
        },
        message: '两次输入的字符不一至'
    },
    number: {
        validator: function (value, param) {
            return /^\d+$/.test(value);
        },
        message: '请输入数字'
    },
    idcard: {
        validator: function (value, param) {
            return idCard(value);
        },
        message:'请输入正确的身份证号码'
    }
});

/* 密码由字母和数字组成,至少6位 */
var safePassword = function (value) {
    return !(/^(([A-Z]*|[a-z]*|\d*|[-_\~!@#\$%\^&\*\.\(\)\[\]\{\}<>\?\\\/\'\"]*)|.{0,5})$|\s/.test(value));
}

var idCard = function (value) {
    if (value.length == 18 && 18 != value.length) return false;
    var number = value.toLowerCase();
    var d, sum = 0, v = '10x98765432', w = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2], a = '11,12,13,14,15,21,22,23,31,32,33,34,35,36,37,41,42,43,44,45,46,50,51,52,53,54,61,62,63,64,65,71,81,82,91';
    var re = number.match(/^(\d{2})\d{4}(((\d{2})(\d{2})(\d{2})(\d{3}))|((\d{4})(\d{2})(\d{2})(\d{3}[x\d])))$/);
    if (re == null || a.indexOf(re[1]) < 0) return false;
    if (re[2].length == 9) {
        number = number.substr(0, 6) + '19' + number.substr(6);
        d = ['19' + re[4], re[5], re[6]].join('-');
    } else d = [re[9], re[10], re[11]].join('-');
    if (!isDateTime.call(d, 'yyyy-MM-dd')) return false;
    for (var i = 0; i < 17; i++) sum += number.charAt(i) * w[i];
    return (re[2].length == 9 || number.charAt(17) == v.charAt(sum % 11));
}

var isDateTime = function (format, reObj) {
    format = format || 'yyyy-MM-dd';
    var input = this, o = {}, d = new Date();
    var f1 = format.split(/[^a-z]+/gi), f2 = input.split(/\D+/g), f3 = format.split(/[a-z]+/gi), f4 = input.split(/\d+/g);
    var len = f1.length, len1 = f3.length;
    if (len != f2.length || len1 != f4.length) return false;
    for (var i = 0; i < len1; i++) if (f3[i] != f4[i]) return false;
    for (var i = 0; i < len; i++) o[f1[i]] = f2[i];
    o.yyyy = s(o.yyyy, o.yy, d.getFullYear(), 9999, 4);
    o.MM = s(o.MM, o.M, d.getMonth() + 1, 12);
    o.dd = s(o.dd, o.d, d.getDate(), 31);
    o.hh = s(o.hh, o.h, d.getHours(), 24);
    o.mm = s(o.mm, o.m, d.getMinutes());
    o.ss = s(o.ss, o.s, d.getSeconds());
    o.ms = s(o.ms, o.ms, d.getMilliseconds(), 999, 3);
    if (o.yyyy + o.MM + o.dd + o.hh + o.mm + o.ss + o.ms < 0) return false;
    if (o.yyyy < 100) o.yyyy += (o.yyyy > 30 ? 1900 : 2000);
    d = new Date(o.yyyy, o.MM - 1, o.dd, o.hh, o.mm, o.ss, o.ms);
    var reVal = d.getFullYear() == o.yyyy && d.getMonth() + 1 == o.MM && d.getDate() == o.dd && d.getHours() == o.hh && d.getMinutes() == o.mm && d.getSeconds() == o.ss && d.getMilliseconds() == o.ms;
    return reVal && reObj ? d : reVal;
    function s(s1, s2, s3, s4, s5) {
        s4 = s4 || 60, s5 = s5 || 2;
        var reVal = s3;
        if (s1 != undefined && s1 != '' || !isNaN(s1)) reVal = s1 * 1;
        if (s2 != undefined && s2 != '' && !isNaN(s2)) reVal = s2 * 1;
        return (reVal == s1 && s1.length != s5 || reVal > s4) ? -10000 : reVal;
    }
};

easyui的validatebox也有做得不到位的地方,比如说,校验类型不能组合使用,大型项目中可能会出现需要定义非常多rule的情况,比如最长六个中文和最长十个中文均要定义一个rul,通过修改源码的方式不难实现这种需求,不过对于这么轻巧的组件来讲,大刀阔斧地修改源码不如重新写一个了,所以还是等作者在某个版本中支持校验类型组合吧。

目前有 3 条留言 其中:访客:3 条, 博主:0 条

  1. peislin : 2012年11月30日18:19:25  -49楼 @回复 回复

    太好了,比较全面!

  2. Aal : 2012年12月11日10:15:34  -48楼 @回复 回复

    刚看过

  3. 瑶琴 : 2013年06月27日10:02:54  -47楼 @回复 回复

    @all手机号好像只能以13开头?不过很好,赞一个 😛

给我留言

留言无头像?


×