正则表达式

JavaScript的正则表达式有两种写法,一种是字面量模式的写法,一种是构造函数模式的写法

1、字面量模式

/表达式/

2、构造函数模式

new RegExp('表达式')

具体的写法如下

javascript 复制代码
匹配表达式.test(匹配内容)

接下来我们都以字面量模式来进行举例学习

第一个:hi

先后输入hi,this,what等字符串,发现hi和this可以匹配,what不能匹配

总结:匹配包含hi的任意字符串

如果我们要严格匹配hi这个字符串要怎么办呢,那就引入\b

\b \B
匹配边界 匹配非边界(类似于hi字符串,没有其他的字符串)

这两个什么意思呢?我们先来看下下面的表达式

javascript 复制代码
\bhi\b		//只能匹配hi字符串,前面或后面多一个字符都不行,如ahi不能匹配,him也不能匹配

接下来看下下面的表达式

javascript 复制代码
\Bhi\B		//匹配任意包含hi的字符串

接下来看下另外一组"\d"和"\D"

\d \D
匹配一个数字 匹配一个非数字

怎么理解呢?我们来看下下面的例子

javascript 复制代码
hi\d	//可以匹配hi1,hi2等字符串,但不能匹配hia,hib,hi22,hi333等字符串
hi\D	//可以匹配hia,hib,hiA,hiB,但不能匹配hi1,hi2,hi22,hi333等字符串

接下来再来看一组"\w"和"\W"

\w \W
匹配字母/数字/下划线 匹配除字母/数字/下划线之外的字符

看下下面的例子

javascript 复制代码
hi\w	//可以匹配hi1,hia,hi_,但不能匹配hi#,hi$,hi11,hiwer等字符串
hi\W	//可以匹配hi#,hi$,但不能匹配hi1,hia,hi_,hi11,hiwer等字符串

再看下一组"^"和"$"

^ $
表示字符串的开头 表示字符串的结束

废话不多说,直接上例子

javascript 复制代码
^hi$	//只能匹配hi字符串,使用^限定了只能是h开头,$限定了只能以i结尾,所以只能匹配hi字符串
^hi		//匹配以hi开头的所有字符串,例如:hi,hia,hi2,hi$等
hi$		//匹配以hi结尾的所有字符串,例如:ahi,55hi,$$$hi等

接下来看一下方括号"[]",这个指的是匹配一堆字符中的一个

直接看例子

javascript 复制代码
^[a-z]at$	//匹配以小写字母a到z开头,以at结尾的字符,例如:cat,bat等,不匹配Cat,Bat,1at等
^[A-Za-z0-9]at$	//匹配A到Z或者a到z或者0到9的字符开头,at结尾的字符串,例如:cat,Cat,1at等,不匹配$at,#at, _at等

方括号"[^]"表示不匹配这个集合中任何一个字符

javascript 复制代码
^[^xyz]at$	//表示不匹配以x、y、z开头,以at结尾的字符串,例如:不匹配xat,yat,zat,但是可以匹配cat,bat等字符串

来看下一组"+","*","?"

+ * ?
表示前一模式可以被重复1次或n次 表示前一模式可以匹配0次或n次 表示前一模式可以匹配0次或1次

举例如下:

javascript 复制代码
^go+gle$	//可以匹配gogle,google,gooogle,goooogle,... 就是可以匹配o重复1次或n次
^go*gle$	//可以匹配ggle,gogle,google,gooogle,... 匹配o重复0次或n次
^go?gle$	//只能匹配ggle,gogle两个字符串,其他不能匹配

接下来看另外一个表达式"{x}",该表达式表示前一模式可以被重复x次

举例如下:

javascript 复制代码
^go{2}gle$	//只能匹配google字符串

再来看比较类似的表达式"{x,y}",表示前一模式可以被重复x到y次。

例如:

javascript 复制代码
^go{2,4}gle$	//只能匹配google,gooogle,goooogle三个字符串

再来看看表达式"{x,}",表示前一模式可以被重复至少x次

例如:

javascript 复制代码
^go{2,}gle$		//匹配google,gooogle,goooogle,... 字符串,就是o这个字符至少有2个

接下来看下"()",这个表示可以指定一堆字符来匹配一个模式

直接看例子:

javascript 复制代码
^(very )*large$	//匹配large,very large,very very large,... 等字符串

接下来看下"|",这代表分支,用来指定几个规则只要匹配一个规则即可。

例如:

javascript 复制代码
^com$|^org$|^net$	//只能匹配com  org  net这三个字符串
^abc.(com|org|net)$	//能匹配abc.com   abc.org    abc.net这三个字符串

接下来看看"\",这个符号表示转移,就是说如果需要匹配类似[,],^,+等有特殊含义的字符,可以用"\"做转义

javascript 复制代码
^1\*\(2\+3\)=6$			//只能匹配  1*(2+3)=6 字符串

把上面的那些表达式弄清楚了,基本就能熟练运用表达式了

另外记一些常用的表达式

javascript 复制代码
[\u4e00-\u9fa5] //表示汉字中的任意一个汉字

其他的就靠大家自己多做练习了。

相关推荐
轻口味1 小时前
命名空间与模块化概述
开发语言·前端·javascript
前端小小王2 小时前
React Hooks
前端·javascript·react.js
迷途小码农零零发2 小时前
react中使用ResizeObserver来观察元素的size变化
前端·javascript·react.js
娃哈哈哈哈呀3 小时前
vue中的css深度选择器v-deep 配合!important
前端·css·vue.js
旭东怪3 小时前
EasyPoi 使用$fe:模板语法生成Word动态行
java·前端·word
ekskef_sef5 小时前
32岁前端干了8年,是继续做前端开发,还是转其它工作
前端
sunshine6415 小时前
【CSS】实现tag选中对钩样式
前端·css·css3
真滴book理喻5 小时前
Vue(四)
前端·javascript·vue.js
蜜獾云5 小时前
npm淘宝镜像
前端·npm·node.js