正则表达式:Regular Expression 通常被用来检索、替换那些符合某个模式(规则)的文本
一些特殊含义的标识:
+ 号代表前面的字符必须至少出现一次(1次或多次)
* 号代表字符可以不出现,也可以出现一次或者多次(0次、或1次、或多次)。
? 问号代表前面的字符最多只可以出现一次(0次、或1次)
\s 代表空格 换行 空字符
$ 代表结束位置
^ 代表开始位置
\d 代表数字
\w 代表单词
\b 代表单词边界
()代表部分
[ ] 代表或者 [ab]表示a或者b
[ ^ ] 表示取反
. 代表任意非空字符
\ 代表转义字符
| 代表或者
{n} 表示数量 n 个
{n,m} 表示数量 n到m 个
{n,} 表示数量至少n个
贪婪模式与非贪婪模式
看了上面介绍的量词,比如{3,5}这个量词,要是在句子种出现了十次,那么他是每次匹配三个还是五个,反正3、4、5都满足3~5的条件,量词在默认下是尽可能多的匹配的,也就是大家常说的贪婪模式
'123456789'.match(/\d{3,5}/g); //["12345", "6789"]
既然有贪婪模式,那么肯定会有非贪婪模式,让正则表达式尽可能少的匹配,也就是说一旦成功匹配不不再继续尝试,做法很简单,在量词后加上 ? 即可
'123456789'.match(/\d{3,5}?/g); //["123", "456", "789"]
属性
g 全文 i忽略大小写 m 多行 (都是只读属性)
lastindex 下一次查询的开始位置(也可以理解为本次搜索结束后最后一个位置的下一个位置)
source 正则表达式文本字符串
对象方法:
reg.test(str)返回true 和 false 表示是否成功 (不用全文/g)
reg.exec(str)匹配返回数组 不匹配返回null
?是禁止贪婪,找到最短的满足条件筛选。
字符串方法:
str.search(/reg/)返回成功的第一个位置
str.match(/reg/g)返回找到所有符合的字符
str.split(/reg/g) 切割字符串
str.replace(/reg/g,'a') 替换字符串
建议多用match 少用exec 因为match 会找到所有满足条件的,而不是像exec每次只找到满足条件的一个来形成数组。
写一个replace的案例
var name = "Doe, John";
console.log(name.replace(/(\w+)\s*, \s*(\w+)/, "$2 $1")); //结果: John Doe
去除字符串内所有的空格:str = str.replace(/\s*/g,"");
去除字符串内两头的空格:str = str.replace(/^\s*|\s*$/g,"");
去除字符串内左侧的空格:str = str.replace(/^\s*/,"");
去除字符串内右侧的空格:str = str.replace(/(\s*$)/g,"");
var str = " 6 6 ";
var str_1 = str.replace(/\s*/g,"");
console.log(str_1); //66
var str = " 6 6 ";
var str_1 = str.replace(/^\s*|\s*$/g,"");
console.log(str_1); //6 6//输出左右侧均无空格
var str = " 6 6 ";
var str_1 = str.replace(/^\s*/,"");
console.log(str_1); //6 6 //输出右侧有空格左侧无空格
写一个验证手机号码的案例
var phoneReg = /^1[3578]\d{9}$/;
var str=13191803645;
console.log(phoneReg.test(str));
验证座机号码
验证规则:区号+号码,区号以0开头,3位或4位
号码由7位或8位数字组成
区号与号码之间可以无连接符,也可以“-”连接
如01088888888,010-88888888,0955-7777777
var re = /^0\d{2,3}-?\d{7,8}$/;
if(re.test(str)){
alert("正确");
}else{
alert("错误");
}
验证身份证号码
var phoneReg = /^[1-9]{1}[0-9]{16}[\dx]$/;
var str='23212319990489489x';
console.log(phoneReg.test(str));
验证邮箱: