一、前言
正则表达式是匹配模式,要么匹配字符,要么匹配位置。
正则里面的元字符太多了,没有系统性,可以分为:
(1)字符匹配攻略
(2)位置匹配攻略
二、字符匹配
包括:两种模糊匹配,字符数组,量词,分支结构。
1.1两种模糊匹配
正则精确匹配乜有意义的,比如正则/saucxs/,只能匹配字符串中的"saucxs"这个子串。
var regex = /saucxs/;
console.log(regex.test('saucxs')); //true
console.log(regex.test('123saucxs4560')); //true
正则很强大的地方就是,实现模糊匹配。
模糊匹配分为:(1)横向模糊匹配;(2)纵向模糊匹配。
1.1.1横向模糊匹配
横向模糊匹配指的是:一个正则可匹配的字符串的长度不是固定的,可以是很多种情况。
实现方式:使用量词。比如:{m,n}表示的连续出现最少m次,最多n次。
比如正则: /ab{2,5}c/表示匹配这样一个字符串:第一个字符是‘a’,接下来第2个到第5个字符是‘b’,最后是字符‘c’。
正则可视化形式如下:
RegExp:/ab{2,5}c/
测试一下:
var regex = /ab{2,5}c/g;
var string = "abc abbc abbbc abbbbc abbbbbc abbbbbbc";
console.log( string.match(regex) ); // ["abbc", "abbbc", "abbbbc", "abbbbbc"]
正则里的g是正则的一个修饰符,表示全局匹配,即按照顺序找到满足匹配的所有子串。
1.1.2纵向模糊匹配
纵向模糊匹配的是,一个正则匹配的字符串,具体到某一个字符时。
实现的方式:使用字符组。比如[abc],表示该字符可以是‘a’,‘b’,‘c’中的任何一个。
比如正则/a[123]b/可以匹配到如下三种字符串'a1b','a2b','a3b'。
可视化过程:
RegExp:/a[123]b/
测试一下
var regex = /a[123]b/g;
var string = "a0b a1b a2b a3b a4b";
console.log( string.match(regex) ); // ["a1b", "a2b", "a3b"]