js正则表达式:验证邮箱格式、密码复杂度、手机号码、QQ号码(转)

原文地址:http://www.sucker-fly.com/archives/476

复制代码
    $(function () {
                $("input[name='sub']").on("click", function () {
                    if (!isEmail($("input[name='email']").val())) {
                        $("span[name='email']").html("邮箱格式错误");
                        return false;
                    }
                    else {
                        $("span[name='email']").html("");
                    }
                    if (checkStrong($("input[name='password']").val()) < 3) {
                        $("span[name='password']").html("密码太过简单");
                        return false;
                    }
                    else {
                        $("span[name='password']").html("");
                    }
                    if (!isQQ($.trim($("input[name='qq']").val()))) {
                        $("span[name='qq']").html("请输入正确的QQ号码");
                        return false;
                    }
                    else {
                        $("span[name='qq']").html("");
                    }
                    if (!isPhone($.trim($("input[name='mnumber']").val()))) {
                        $("span[name='mnumber']").html("请输入正确的手机号码");
                        return false;
                    }
                    else {
                        $("span[name='mnumber']").html("");
                    }
                    return true;
                });
            });
            /**
            * 检查字符串是否为合法QQ号码
            * @param {String} 字符串
            * @return {bool} 是否为合法QQ号码
            */
            function isQQ(aQQ) {
                var bValidate = RegExp(/^[1-9][0-9]{4,9}$/).test(aQQ);
                if (bValidate) {
                    return true;
                }
                else
                    return false;
            }
            /**
            * 检查字符串是否为合法手机号码
            * @param {String} 字符串
            * @return {bool} 是否为合法手机号码
            */
            function isPhone(aPhone) {
                var bValidate = RegExp(/^(0|86|17951)?(13[0-9]|15[012356789]|18[0-9]|14[57])[0-9]{8}$/).test(aPhone);
                if (bValidate) {
                    return true;
                }
                else
                    return false;
            }
            /**
            * 检查字符串是否为合法email地址
            * @param {String} 字符串
            * @return {bool} 是否为合法email地址
            */
            function isEmail(aEmail) {
                var bValidate = RegExp(/^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/).test(aEmail);
                if (bValidate) {
                    return true;
                }
                else
                    return false;
            }
            /**
            * 检查字符串是否是整数
            * @param {String} 字符串
            * @return {bool} 是否是整数
            */
            function isInteger(s) {
                var isInteger = RegExp(/^[0-9]+$/);
                return (isInteger.test(s));
            }
            /*
                判断字符类型
            */
            function CharMode(iN) {
                if (iN >= 48 && iN <= 57) //数字  
                    return 1;
                if (iN >= 65 && iN <= 90) //大写字母  
                    return 2;
                if (iN >= 97 && iN <= 122) //小写  
                    return 4;
                else
                    return 8; //特殊字符  
            }
            /*
                统计字符类型
            */
            function bitTotal(num) {
                modes = 0;
                for (i = 0; i < 4; i++) {
                    if (num & 1) modes++;
                    num >>>= 1;
                }
                return modes;
            }
            /*
                返回密码的强度级别
            */
            function checkStrong(sPW) {
                if (sPW.length <= 4)
                    return 0; //密码太短  
                Modes = 0;
                for (i = 0; i < sPW.length; i++) {
                    //测试每一个字符的类别并统计一共有多少种模式.  
                    Modes |= CharMode(sPW.charCodeAt(i));
                }
                return bitTotal(Modes);
            }
复制代码

 



如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!欢迎各位转载,但是未经作者本人同意,转载文章之后必须在文章页面明显位置给出作者和原文连接,否则保留追究法律责任的权利。
posted @   高山-景行  阅读(3644)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
点击右上角即可分享
微信分享提示