javascript较全常用的表达正则验证,js中采用test()方法

更新日期: 2017-10-20阅读: 5k标签: 正则

RegExp对象

正则表达式描述了字符的模式对象。当您检索某个文本时,可以使用一种模式来描述要检索的内容。RegExp 就是这种模式。
var patt=new RegExp(pattern,modifiers);
//等价于
var patt=/pattern/modifiers;//字面量(推荐) 必须用(//)来包裹pattern

模式pattern描述了一个表达式模型。修饰符(modifiers)描述了检索是否是全局,区分大小写等。i : 表示区分大小写字母匹配。m :表示多行匹配。g : 表示全局匹配。

test()的使用

test 方法用于正则规则在指定的字符串中是否具有符合的匹配结果,如果匹配到则返回true,否则返回false。

let reg = /^[1-9]\d*$/;  
console.log(reg.test('123'));     //返回true

注意在非全局模式下使用,如果在全局模式下,匹配结果将会影响下一次匹配

let reg = /^[1-9]\d*$/g; //这个/g为全局模式 
console.log(reg.test('123'));     //返回true
console.log(reg.test('123'));     //返回false

exec方法

exec方法返回的是对应匹配的数组,如果没有匹配则返回null

let r = /(\d+)-(\w+)/;
console.log(r.exec("2017-love-b"));//返回整个匹配的字符串
/*
[0:"2013-love",1:"2017",2:"love",index:0,input:"2017-love-b"]
*/

exec的方法功能较为强大,而我们常规使用匹配,只需要要一次结果即可,个人更推荐采用test()的非全局方式,基本可以应付常规的开发了

Js常用正则

验证手机号: /^(((13[0-9]{1})|(147)|(15[0-9]{1})|(17[0-9]{1})|(18[0-9]{1}))+\d{8})$/;

验证邮箱: /^(\w-*\.*)+@(\w-?)+(\.\w{2,})+$/;

验证数字组成:/^[0-9]{1,20}$/ (0-9的数组,1到20位)

验证账号:/^[a-zA-Z]{1}([a-zA-Z0-9]|[._]){4,19}$/ (只能输入5-20长度,字母开头,可带数字,‘_’,'.')
验证密码:/^(\w){6,20}$/ (只能输入6-20个字母、数字、下划线)

验证中文姓名:/^([\u4e00-\u9fa5]{2,20}|[a-zA-Z\.\s]{1,20})$/ (2个字以上的中文名称)

验证普通电话、传真号码: /^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/ (可以“+”开头,除数字外,可含有“-” )

验证邮政编码:/^[a-zA-Z0-9 ]{3,12}$/

验证搜索关键词:/^[^`~!@#$%^&*()+=|\\\][\]\{\}:;'\,.<>/?]{1}[^`~!@$%^&()+=|\\\][\]\{\}:;'\,.<>?]{0,19}$/

验证IP地址: /^(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])$/

验证URL:/(http|ftp|https):\/\/[\w\-_]+(\.[\w\-_]+)+([\w\-\.,@?^=%&:/~\+#]*[\w\-\@?^=%&/~\+#])?/

验证数字:

/^\d+$/  //非负整数(正整数 + 0) 
/^[0-9]*[1-9][0-9]*$/  //正整数 
/^((-\d+)|(0+))$/  //非正整数(负整数 + 0) 
/^-[0-9]*[1-9][0-9]*$/  //负整数 
/^-?\d+$/    //整数 
/^\d+(\.\d+)?$/  //非负浮点数(正浮点数 + 0) 
/^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$/  //正浮点数 
/^((-\d+(\.\d+)?)|(0+(\.0+)?))$/  //非正浮点数(负浮点数 + 0) 
/^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$/  //负浮点数 
/^(-?\d+)(\.\d+)?$/  //浮点数

验证15/18位身份证

var vcity={ 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:"国外"  
           };  
  
checkCard = function()  
{  
    var card = document.getElementById('card_no').value;  
    //是否为空  
    if(card === '')  
    {  
        alert('请输入身份证号,身份证号不能为空');  
        document.getElementById('card_no').focus;  
        return false;  
    }  
    //校验长度,类型  
    if(isCardNo(card) === false)  
    {  
        alert('您输入的身份证号码不正确,请重新输入');  
        document.getElementById('card_no').focus;  
        return false;  
    }  
    //检查省份  
    if(checkProvince(card) === false)  
    {  
        alert('您输入的身份证号码不正确,请重新输入');  
        document.getElementById('card_no').focus;  
        return false;  
    }  
    //校验生日  
    if(checkBirthday(card) === false)  
    {  
        alert('您输入的身份证号码生日不正确,请重新输入');  
        document.getElementById('card_no').focus();  
        return false;  
    }  
    //检验位的检测  
    if(checkParity(card) === false)  
    {  
        alert('您的身份证校验位不正确,请重新输入');  
        document.getElementById('card_no').focus();  
        return false;  
    }   
    return true;  
};  
  
  
//检查号码是否符合规范,包括长度,类型  
isCardNo = function(card)  
{  
    //身份证号码为15位或者18位,15位时全为数字,18位前17位为数字,最后一位是校验位,可能为数字或字符X  
    var reg = /(^\d{15}$)|(^\d{17}(\d|X)$)/;  
    if(reg.test(card) === false)  
    {  
        return false;  
    }  
  
    return true;  
};  
  
//取身份证前两位,校验省份  
checkProvince = function(card)  
{  
    var province = card.substr(0,2);  
    if(vcity[province] == undefined)  
    {  
        return false;  
    }  
    return true;  
};  
  
//检查生日是否正确  
checkBirthday = function(card)  
{  
    var len = card.length;  
    //身份证15位时,次序为省(3位)市(3位)年(2位)月(2位)日(2位)校验位(3位),皆为数字  
    if(len == '15')  
    {  
        var re_fifteen = /^(\d{6})(\d{2})(\d{2})(\d{2})(\d{3})$/;   
        var arr_data = card.match(re_fifteen);  
        var year = arr_data[2];  
        var month = arr_data[3];  
        var day = arr_data[4];  
        var birthday = new Date('19'+year+'/'+month+'/'+day);  
        return verifyBirthday('19'+year,month,day,birthday);  
    }  
    //身份证18位时,次序为省(3位)市(3位)年(4位)月(2位)日(2位)校验位(4位),校验位末尾可能为X  
    if(len == '18')  
    {  
        var re_eighteen = /^(\d{6})(\d{4})(\d{2})(\d{2})(\d{3})([0-9]|X)$/;  
        var arr_data = card.match(re_eighteen);  
        var year = arr_data[2];  
        var month = arr_data[3];  
        var day = arr_data[4];  
        var birthday = new Date(year+'/'+month+'/'+day);  
        return verifyBirthday(year,month,day,birthday);  
    }  
    return false;  
};  
  
//校验日期  
verifyBirthday = function(year,month,day,birthday)  
{  
    var now = new Date();  
    var now_year = now.getFullYear();  
    //年月日是否合理  
    if(birthday.getFullYear() == year && (birthday.getMonth() + 1) == month && birthday.getDate() == day)  
    {  
        //判断年份的范围(3岁到100岁之间)  
        var time = now_year - year;  
        if(time >= 3 && time <= 100)  
        {  
            return true;  
        }  
        return false;  
    }  
    return false;  
};  
  
//校验位的检测  
checkParity = function(card)  
{  
    //15位转18位  
    card = changeFivteenToEighteen(card);  
    var len = card.length;  
    if(len == '18')  
    {  
        var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);   
        var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');   
        var cardTemp = 0, i, valnum;   
        for(i = 0; i < 17; i ++)   
        {   
            cardTemp += card.substr(i, 1) * arrInt[i];   
        }   
        valnum = arrCh[cardTemp % 11];   
        if (valnum == card.substr(17, 1))   
        {  
            return true;  
        }  
        return false;  
    }  
    return false;  
};  
  
//15位转18位身份证号  
changeFivteenToEighteen = function(card)  
{  
    if(card.length == '15')  
    {  
        var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);   
        var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');   
        var cardTemp = 0, i;     
        card = card.substr(0, 6) + '19' + card.substr(6, card.length - 6);  
        for(i = 0; i < 17; i ++)   
        {   
            cardTemp += card.substr(i, 1) * arrInt[i];   
        }   
        card += arrCh[cardTemp % 11];   
        return card;  
    }  
    return card;  
};

待补充......如有错误请指正!

链接: https://www.fly63.com/article/detial/6

js使用正则过滤emoji表情符号

手机端常常会遇到用户输入框,输入emoji,如果是数据库是UTF8,会遇到报错,原因是:UTF-8编码有可能是两个、三个、四个字节。Emoji表情是4个字节,而Mysql的utf8编码最多3个字节,所以数据插不进去。

一次记住js的6个正则方法

来记忆一些常用特殊字符,这个是正则本身的范畴了,是不是总觉得记不住?其实我也记不住,每次都是去搜索和online验证来完成一些任务。我也困恼过,其实最后还是因为自己写的少吧,唯手熟尔。。。

密码强度的正则表达式(JavaScript)总结

本文给出了两个密码强度的正则表达式方案,一个简单,一个更复杂和安全。并分别给出了两个方案的解析和测试程序。一般大家可以根据自己的项目的实际需要,自行定义自己的密码正则约定。

JavaScript判断字符串包含中文字符的方法总结

JS中判断一个字符串是否包含汉字,下面就介绍2中常用的实现方法:用正则表达式判断、用 Unicode 字符范围判断。

js常用正则表达式验证大全(整理详细且实用)

正则表达式对象用来规范一个规范的表达式,本文讲的是JS正则表达式大全(整理详细且实用),包括校验数字、字符、一些特殊的需求等等

javascript 正则表达式之分组与前瞻匹配详解

本文主要讲解javascript 的正则表达式中的分组匹配与前瞻匹配的,需要对正则的有基本认识。分组匹配:捕获性分组匹配、非捕获性分组匹配。前瞻匹配:正向前瞻匹配: (?=表达式) 后面一定要匹配有什么、反向前瞻匹配: (?!表达式) 后面一定不能要有什么

利用正则表达式去除所有html标签,只保留文字

后台将富文本编辑器中的内容返回到前端时如果带上了标签,这时就可以利用这种方法只保留文字。利用正则表达式去除所有html标签,只保留文字

正则表达式后行断言 • 探索 ES2018 和 ES2019

先后行断言(Lookaround Assertion)是正则表达式中的一个构造,明确了当前位置的前后字符序列,但没有其他副作用。当前 JavaScript 唯一支持的 Lookaround Assertion 是 先行断言,其匹配当前位置接下来的字符序列

循环下的正则匹配?说说正则中的lastIndex

正则有一个属性叫lastIndex,它表示正则下一次匹配时的起始位置。一般情况下我们是使用不到它的,但在正则中包含全局标志g时,正则的test和exec方法就会使用到它

常用JavaScript正则表达式整理

在表单验证中,正则表达式书写起来特别繁琐,本文整理了15个常用的JavaScript正则表达式,其中包括用户名、密码强度、整数、数字、电子邮件地址(Email)、手机号码、身份证号、URL地址、 IPv4地址

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!