jquery.validate.js 和 layer实现漂亮的表单验证特效

/**
 * 主要用于用户表单校验逻辑 显示on 2017/12/9.
 */
$(function(){
    // 手机号码验证
    jQuery.validator.addMethod("isMobile", function(value, element) {
        var length = value.length;
        var mobile = /^(13[0-9]{9})|(18[0-9]{9})|(14[0-9]{9})|(17[0-9]{9})|(15[0-9]{9})$/;
        return this.optional(element) || (length == 11 && mobile.test(value));
    }, "请正确填写您的手机号码");

    // 邮箱验证规则
    jQuery.validator.addMethod("isEmail", function(value, element) {
        var reg = /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(.[a-zA-Z0-9_-])+/;
        return this.optional(element) || (reg.test(value));
    }, "请正确填写您的邮箱");

    // 下拉框的验证
    jQuery.validator.addMethod("isSelect", function(value, element) {
        return this.optional(element)|| (value!=-1);
    }, "请选择");

});

//校验用户表单逻辑
function checkUserForm(id,operate){
    validator = $("#editUserForm").validate({
        //    onfocusout: false,  //失去焦点
        onkeyup: false, // 键盘是否按下
        //onclick: false,  //是否单击
        rules: {
            userName: {
                required: true,
                //异步验证 开始
                remote: {
                    url:   ctx + "/sys/manager/authc_json/checkRepeatUserName.shtml",//发送请求的url地址
                    type: "post", //请求方式
                    async:false,
                    dataType: "json",//接收的数据类型
                    cache:false,
                    data: {
                        userName: function () {
                            return $("#editUserForm #userName").val();
                        },
                        userID:id?id:0,
                        operate:operate
                    },
                    dataFilter: function (data, type) { //过滤返回结果
                        if(data == "true"){
                            return true;  //true代表用户名称还未存在
                        }else{
                            return false; //false代表用户名称已经存在
                        }
                    }
                }
                //异步验证 结束
            },
            roleID:{
                required:true,
                isSelect:true
            },
            realname:{
                required: true
            },
            phone:{
                required:true,
                isMobile:true
            },
            email:{
                isEmail:true
            }

        },
        messages: {
            userName: {
                required: "请填写您的账号",
                remote:"录入的账号名称重复,请重新输入"
            },
            realname:{
                required: "请填写您的真实姓名"
            },
            roleID:{
                required:"请选择关联角色",
                isSelect:"请选择关联角色"
            },
            phone:{
                required:"请填写您的手机号码",
                isMobile:'手机号码格式不正确'
            },
            email:{
                isEmail:'邮箱格式不正确'
            }
        }
    });

}

 

/**
 * 扩展插件 错误提示用layer 显示on 2017/12/9.
 */
(function ($) {
    "use strict";
    $.fn.extend($.validator.defaults, {
        //重写showErrors
        showErrors: function (errorMap, errorList) {
            $.each(errorList, function (i, v) {
                //在此处用了layer的方法,显示效果更美观
                if($(v.element)[0].tagName.indexOf("SELECT")>-1){ // 针对于select2  控件做了调整
                    layer.tips(v.message, $(v.element).next(), {icon: 2 , time: 2000 });
                }else{
                    layer.tips(v.message, v.element, {icon: 2 , time: 2000 });
                }
                return false;
            });
        }
    });
})(jQuery);-------------大家可以尝试下
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qq_28917403

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值