美文网首页
【转载】前端常见正则表达式

【转载】前端常见正则表达式

作者: Eternal丶 | 来源:发表于2018-05-07 11:06 被阅读0次

记录一下前端常用正则表达式,实际工作中要根据自己的项目提取合适的去使用

let regExp = {
        // 数字正则
        isNumber: function(str) {
            let reg = /^-?\d*\.?\d+$/;
            if (reg.test(str)) {
                return true
            } else {
                return false
            }
        },
        // 正数正则
        isPosNumber: function(str) {
            let reg = /^\d*\.?\d+$/;
            if (reg.test(str)) {
                return true
            } else {
                return false
            }
        },
        // 负数正则
        isNegNumber: function(str) {
            let reg = /^-\d*\.?\d+$/;
            if (reg.test(str)) {
                return true
            } else {
                return false
            }
        },
        // 整数正则
        isInteger: function(str) {
            let reg = /^-?\d+$/;
            if (reg.test(str)) {
                return true
            } else {
                return false
            }
        },
        // 正整数正则
        isPosInteger: function(str) {
            let reg = /^\d+$/;
            if (reg.test(str)) {
                return true
            } else {
                return false
            }
        },
        // 负整数正则
        isNegInteger: function(str) {
            let reg = /^-\d+$/;
            if (reg.test(str)) {
                return true
            } else {
                return false
            }
        },
        // 用户名正则
        isUserName: function(str) {
            // 4到16位(字母,数字,下划线,减号)
            let reg = /^[a-zA-Z0-9_-]{4,16}$/;
            if (reg.test(str)) {
                return true
            } else {
                return false
            }
        },
        // 包含中文正则
        isChinese: function(str) {
            let reg = /[\u4E00-\u9FA5]/;
            if (reg.test(str)) {
                return true
            } else {
                return false
            }
        },
        // 密码正则
        isPassword: function(str) {
            // 以字母开头,长度在6~18之间,只能包含字母、数字和下划线
            let reg = /^[a-zA-Z]\w{5,17}$/;
            if (reg.test(str)) {
                return true
            } else {
                return false
            }
        },
        // 邮箱正则
        isEmail: function(str) {
            let reg = /^([A-Za-z0-9_\-\.\u4e00-\u9fa5])+\@([A-Za-z0-9_\-\.])+\.([A-Za-z]{2,8})$/;
            if (reg.test(str)) {
                return true
            } else {
                return false
            }
        },
        // 手机号正则
        isPhone: function(str) {
            // 移动号段:134 135 136 137 138 139 147 148 150 151 152 157 158 159 172 178 182 183 184 187 188 198
            // 联通号段:130 131 132 145 146 155 156 166 171 175 176 185 186
            // 电信号段:133 149 153 173 174 177 180 181 189 199
            // 虚拟运营商:170
            let reg = /^(13[0-9]|14[5-9]|15[012356789]|166|17[0-8]|18[0-9]|19[8-9])[0-9]{8}$/;
            if (reg.test(str)) {
                return true
            } else {
                return false
            }
        },
        // 固定电话正则
        isTelephone: function(str) {
            let reg = /^(\(\d{3,4}\)|\d{3,4}-|\s)?\d{8}$/;
            if (reg.test(str)) {
                return true
            } else {
                return false
            }
        },
        // 第二代身份证号正则
        isIDCard: function(str) {
            let reg = /^[1-9]\d{5}(18|19|20)\d{2}((0[1-9])|(1[0-2]))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$/;
            if (reg.test(str)) {
                return true
            } else {
                return false
            }
        },
        // QQ号正则
        isQQNumber: function(str) {
            let reg = /^[1-9][0-9]{4,10}$/;
            if (reg.test(str)) {
                return true
            } else {
                return false
            }
        },
        // 微信号正则
        isWeChatNumber: function(str) {
            // 6至20位,以字母开头,字母,数字,减号,下划线
            let reg = /^[a-zA-Z]([-_a-zA-Z0-9]{5,19})+$/;
            if (reg.test(str)) {
                return true
            } else {
                return false
            }
        },
        // 特殊字符正则
        isSpeNumber: function(str) {
            let reg = /["'<>%;)(&+]+-!!@#$~/;
            if (reg.test(str)) {
                return true
            } else {
                return false
            }
        },
        // IP地址正则
        isIP: function(str) {
            let reg = /^\d+\.\d+\.\d+\.\d+$/;
            if (reg.test(str)) {
                return true
            } else {
                return false
            }
        },
        // 邮政编码正则
        isPostCode: function(str) {
            let reg = /^[1-9]{1}(\d+){5}$/;
            if (reg.test(str)) {
                return true
            } else {
                return false
            }
        }
    };

附上我比较喜欢用的一个正则图形化网站,有兴趣的可以试试:正则图形化

参考资料:
如何判断用户浏览器以及一些前端常用的正则表单验证
前端开发中的 正则表达式 及常用正则表达式大全

相关文章

  • 【转载】前端常见正则表达式

    记录一下前端常用正则表达式,实际工作中要根据自己的项目提取合适的去使用 附上我比较喜欢用的一个正则图形化网站,有兴...

  • JS常用正则表达式备忘录

    摘要: 玩转正则表达式。 原文:JS常用正则表达式备忘录 作者:前端小智 Fundebug经授权转载,版权归原作者...

  • 常用正则表达式

    常用正则表达式大全!(例如:匹配中文、匹配html)目录导航一、常见正则表达式二、正则表达式应用一、常见正则表达式...

  • React常见的15个问题

    摘要: 学习React。 原文:React.js 常见问题 作者:前端小智 Fundebug经授权转载,版权归原作...

  • 部分iphone无法识别.webp格式图片问题解决

    找后台更换图片 前端使用正则表达式将“.webp”更换成“.jpg”(前提是该格式的图片存在) 以下内容转载于ht...

  • 前端面试集锦(1)

    前端面试集锦(转载) 转载地址:前端开发面试题 以下皆为转载 前端开发知识点: 作为一名前端工程师,无论工作年头长...

  • vue(2) - 收藏集 - 掘金

    javascript 正则表达式总结 - 前端 - 掘金为什么要使用正则表达式 正则表达式通过由普通字符和特殊字符...

  • Web前端------JS正则表达式(转载)

    文章转载自: 过目不忘JS正则表达式 概述 正则表达式,有木有人像我一样,学了好几遍却还是很懵圈,学的时候老明白了...

  • 正则表达式(4)----常用的正则表达式

    本文为转载文章转自W3Cschool,转载请注明出处正则表达式(1)---语法讲解 正则表达式(2)---匹配规则...

  • 正则相关

    正则表达式基本语法 正则表达式常见字符 正则表达式特殊字符 正则表达式数量词 正则表达式边界匹配 正则表达式逻辑或...

网友评论

      本文标题:【转载】前端常见正则表达式

      本文链接:https://www.haomeiwen.com/subject/zlemrftx.html