根据正则表达式做出的限定(匹配) ,范围之内的都是可以的
test()方法,返回值为布尔值
exec()方法,可以返回匹配信息
console.log(/(ab){2}/.test('ababac1'));
console.log(/(\d{4})-(\d{1,2})-(\d{1,2})/.exec('2020-12-7'));
console.log(/(\d{4})-(\d{1,2})-(\d{1,2})/.exec('2020-12-7')[0]);
console.log(/(\d{4})-(\d{1,2})-(\d{1,2})/.exec('2020-12-7')[1]);
控制台输出
具体操作:
//匹配对应的字符串
console.log(/a/.test('a'));
//范围(这里的1也是一个范围,只是范围比较小,只有1而已)
console.log(/[123456789]/.test('890127908271'));
//范围,效果如上,存在顺序(依照ASCII表)
console.log(/[1-9]/.test('890127908271'));
//合并起来只有-之间有顺序,范围之间没有循序
console.log(/[1-9A-Za-z]/.test('a'));
量词
正则匹配会存在贪婪匹配也就是尽可能多的匹配
console.log(/[a]{3}/.test('aaaa'));
console.log(/a+/.exec('abc'));
console.log(/a?/.exec('abc'));
console.log(/a*/.exec('aaaaaaa'));
贪婪模式转换为非贪婪模式(按小的匹配)
(多加一个?)
console.log(/a+?/.exec('abc'));
console.log(/a??/.exec('abc'));
console.log(/a*?/.exec('aaaaaaa'));
反向引用
// 这里的\1就是用到了反向引用,引用的是第一个匹配到的字符
console.log(/(a{1})\1/.exec('aa'));
选择
也就是或的关系,一旦匹配上就不再回头
//满足一个即可,就不会·继续检测了,自左到右
console.log(/12|34|56/.exec('123456123456'));
断言、环视
\b 单词边界 \B 非单词边界
console.log(/\ban\b/.exec('an apple an'));
console.log(/\ban/.exec('an apple an'));
console.log(/an\b/.exec('an apple an'));
//匹配以an开头,^表示开头匹配
console.log(/^an/.exec('an apple'));
//匹配以an结尾,¥表示结尾匹配
console.log(/an$/.exec('apple an'));
//环视(如下:仅仅匹配ab的a,不匹配ac的a)
console.log(/a(?=b)/.exec('ab'));
console.log(/a(?=b)/.exec('ac'));
//表示和上面相反,匹配不是ab的a
console.log(/a(?!b)/.exec('ac'));
匹配模式
g(global)i (ignore case) m (multipy)
m:识别换行 \n
console.log('1a 2A 3a'.replace(/a/gi,'b'));
console.log(/^a/m.test('b\na')); //返回值为true
优先级
创建
通过字面量来创建RegExp对象
const exp=/a{2}/
通过构造函数来创建RegExp对象
//通过构造函数传参
const exp=new RegExp('a{2}')
console.log(exp.exec('aabb'));
原本的比较简单创建方法也是RegExp对象
console.log(/(\d{4})-(\d{1,2})-(\d{1,2})/.exec('2020-12-7'));
console.log(RegExp.$1);
//值得注意的是这里得到0的位置是未定义的(undefined)
console.log(RegExp.$0);