javasript正则表达式

来源:互联网 发布:魔兽美工代码编辑器 编辑:程序博客网 时间:2024/06/07 06:57

下定决心认真钻研前端,接下来的近一年的时间我会努力每天写一篇博客,作为打卡。加油!

元字符

( [ { \ ^ $ | ) ? * + .

预定义的特殊字符

字符正则描述\t/\t/制表符\n/\n/制表符\r/\r/回车符\f/\f/换页符\a/\a/alert字符\e/\e/escape字符\cX/\cX/与X相对应的控制字符\b/\b/与回退字符\v/\v/垂直制表符\0/\0/空字符

字符类

简单类

原则上正则的一个字符对应一个字符,我们可以用[]把它们括起来,让[]这个整体对应一个字符。

alert(/[abc]/.test("a"));

负向类

也是在那个括号里做文章,前面加个元字符进行取反,表示匹配不能为括号里面的字符。

范围类

还是在那个中括号里面做文章。有时匹配的东西过多,而且类型又相同,全部输入太麻烦,我们可以用它。特征就是在中间加了个横线。

组合类

还是在那个中括号里面做文章。允许用中括号匹配不同类型的单个字符。

预定义类

还是在那个中括号里面做文章,不过它好像已经走到尽头了。由于是中括号的马甲,因此它们还是对应一个字符。

字符等同于描述.[^\n\r]除了换行和回车之外的任意字符\d[0-9]数字字符\D[^0-9]非数字字符\s[ \t\n\x0B\f\r]空白字符\S[^ \t\n\x0B\f\r]非空白字符\w[a-zA-Z_0-9]单词字符(所有的字母)\W[^a-zA-Z_0-9]非单词字符

量词

由于元字符与特殊字符或字符类或者它们的组合(中括号)甚至它们的马甲(预定义类)都是一对一进行匹配。我们要匹配“司徒正美这个词”,最简单都要/..../,如果长到50多个字符岂不是要死人。因此我们逼切需要一个简单的操作,来处理这数量关系。

简单量词

代码类型描述?软性量词出现零次或一次*软性量词出现零次或多次(任意次)+软性量词出现一次或多次(至道一次){n}硬性量词对应零次或者n次{n,m}软性量词至少出现n次但不超过m次{n,}软性量词至少出现n次(+的升级版)

贪婪量词,惰性量词与支配性量词

贪婪量词,上面提到的所有简单量词。就像成语中说的巴蛇吞象那样,一口吞下整个字符串,发现吞不下(匹配不了),再从后面一点点吐出来(去掉最后一个字符,再看这时这个整个字符串是否匹配,不断这样重复直到长度为零)

隋性量词,在简单量词后加问号。由于太懒了,先吃了前面第一个字符,如果不饱再捏起多添加一个(发现不匹配,就读下第二个,与最初的组成一个有两个字符串的字符串再尝试匹配,如果再不匹配,再吃一个组成拥有三个字符的字符串……)。其工作方式与贪婪量词相反。

支配性量词,在简单量词后加加号。上面两种都有个不断尝试的过程,而支配性量词却只尝试一次,不合口味就算了。就像一个出身高贵居支配地位的公主。但你也可以说它是最懒量词。由于javascript不支持,所以它连出场的机会也没有了。

分组

到目前为止,我们只能一个字符到匹配,虽然量词的出现,能帮助我们处理一排密紧密相连的同类型字符。但这是不够的,下面该轮到小括号出场了,中括号表示范围内选择,大括号表示重复次数。小括号允许我们重复多个字符。

反向引用

反向引用标识由正则表达式中的匹配组捕获的子字符串。每个反向引用都由一个编号或名称来标识,并通过“\编号”表示法进行引用。

候选

继续在分组上做文章。在分组中插入管道符(“|”),把它划分为两个或多个候多项。

非捕获性分组

并不是所有分组都能创建反向引用,有一种特别的分组称之为非捕获性分组,它是不会创建反向引用。反之,就是捕获性分组。要创建一个非捕获性分组,只要在分组的左括号的后面紧跟一个问号与冒号就行了。

前瞻

继续在分组内做文章。前瞻与后瞻其实都属于零宽断言,但javascript不支持后瞻。

零宽断言正则名称描述(?=exp)正向前瞻匹配exp前面的位置(?!exp)负向前瞻匹配后面不是exp的位置(?<=exp)正向后瞻匹配exp后面的位置不支持(?<!exp)负向后瞻匹配前面不是exp的位置不支持

边界

一个要与字符类合用的东西。

边界正则名称描述^开头注意不能紧跟于左中括号的后面$结尾 \b单词边界指[a-zA-Z_0-9]之外的字符\B非单词边界 

0 0
原创粉丝点击