因为查找是一个比较复杂的东西,我们想更加准确快速找到自己想要的
它可以定义一种字符串逻辑的公式,来和要查找的字符串做匹配,找到自己想要的。
定义:
1. 使用 /规则/修饰符
var patt = /Hello CoolDog/i;
2. 新创建一个RegExp对象,给两个参数分别为规则和修饰符,修饰符可省略
var patt1 = new RegExp("hello","i");
常用的修饰符:
“i”:不区分大小写
var patt = /HelloCoolDog/i;//i 不区分大小写 var patt1 = new RegExp("hello","i");
“g”:全局匹配,从找到的下一个下标开始再继续往后查找,一直到字符串结束。
var patt2= /o/g;//全局查找 var result= str.replace(patt2,"O"); document.write(result);
字符模式
[Hel]:从里面字符中任意一个去匹配字符串
var str ="Hello CoolDog"; var patt = /[Hel]/g;
[0-9];匹配任意一个数字
var str ="HelloC2342311345oolDog"; var patt1= /[0-9]/g; var result= str.match(patt1); document.write(result);
[a-z]:匹配所有小写字母
varstr ="HelloC2342311345oolDog"; var patt1 = /[a-z]/g; var result = str.match(patt1); document.write(result);
[A-Z]:匹配所有的大写字母
var str ="HelloC2342311345oolDog";
var patt1 = /[A-Z]/g; var result = str.match(patt1); document.write(result);
(a|x):匹配a或者x,a也能用[]来代替
var str ="HeadxlloC2342311345oolDog"; var patt1= /(a|x)/g; var result= str.match(patt1); document.write(result);
常用的元字符:
\w :单词字符,包括所有字母和下划线,w是word的缩写。
var str ="___——____*&%¥#HeadxlloC234231!^?_+^1345oolDog"; var patt = /\w|/g;//word var result= str.match(patt); document.write(result);
\s :空格 s是space的缩写
var str ="__ HeadxlloC2342311345oolDog"; var patt = /\s|/g;//space var result= str.replace(patt,"&"); document.write(result);
\d :数字 ,digital的意思
var patt = /\d|/g;//
常用的量词:
var patt= /oo+/g;//匹配一个或多个 var patt1= /oo*/g;//匹配0个或多个 var patt2= /oo?/;//匹配0个或者一个
o+:找到一个或多个o
o* :找到0个或者多个
o?:找到0个或者1个
var patt= /o{2}/g;//指定了o的个数 var patt1= /o{2,3}/g;//指定至少两个最多三个 var patt2= /o{2,}/g;//指定至少两个最多三个
o{3}:指定具体的个数
o{2,3}:指定一个有范围的区间,最少两个最多三个
o{2,}:最少两个
^:必须以它后面的内容为开头
$:以什么内容结束
RegExp常用的两种方法:
Exec():返回的是找到符合正则表达式新的字符串
var patt= /\w+/g; var str = "goodafternoon"; var result = patt.exec(str);
Test():返回的是true或者false 当字符串满足正则表达式时位true否则为false
var str= prompt("请输入密码"); var patt = /[a-z]|[A-Z]\w{5,17}/i; if (patt.test(str)){ document.write("您输入的密码正确"); }else { document.write("对不起,您输入的密码不符合规范!") }