正则法则

** 一 正则是什么?**
正则就是一个规则,用来处理字符串的规则
1、正则匹配

  • 编写一个规则,验证某个字符串是否匹配这个规则,用test方法

2、正则捕获

  • 编写一个规则,在一个字符串中,把符合规则的内容都获取到,使用方法:正则的exec方法、字符串中的split、replace、match等方法都支持正则
  • 3、应用场合
  • 数据验证、文本替换、内容检索、过滤内容
  • 4、正则表达式创建
    在这里插入图片描述

二、’元字符和修饰符
任何正则都是有这两个组成的
-修饰符
g(global):全局匹配
i(ignore):忽略大小写匹配
m(mutiline):多行匹配
-元字符
[量词元字符]
+:让前面的元字符出现1到多次
?:出现0到1次
*:出现0到多次
{n}:出现n次
{n,}:出现n到多次
{n,m}:出现n到m次
[特殊意义的元字符]
-\ 转义字符
-.除了\n(换行符)以外的任意字符
-\d 匹配一个0-9的任意字符
\D 匹配一个非0-9的任意字符
\w 匹配一个[0-9a-zA-Z_]之间的任意字符
\s 匹配一个任意空白符
\b 匹配一个边界符(单词的左右,-的左右两边)
x|y 匹配两者中的其中一个
[a-z] 匹配a-z中的任意一个字符
[^a-z] 匹配非a-z中的任意一个字符
[xyz] 匹配xyz中的其中一个
[^xyz]匹配除了xyz以外的任意字符
()正则小分组
^ 以某一个元字符开始
$ 以某一个元字符结束
?: 只匹配不捕获
?=正向预查

三、 贪婪与吝啬
贪婪:正则在匹配的时候,默认返回是最长的结果
吝啬:在量词后面加上问号,表示默认返回最短的符合
在这里插入图片描述

例如:var reg=/

.</p>/
var str=“

我是第一个

我是第二个


console.log(reg.exec(str))
//在控制台输出后,显示的内容会是“

我是第一个

我是第二个


// 当var reg=/

.?</p>/时,只会显示“

我是第一个

"
这说明在贪婪模式中,它会把字符串中的所有内容找到;非贪婪模式会在找到打一个

后停止寻找

可以试试!

四、几种常见的匹配规则
匹配手机号:
var reg=/^1(38|55|31|84)\d{8}KaTeX parse error: Expected group after '^' at position 27: … var reg=/^̲\d{17}[\dxX]/
qq邮箱:
var reg=/^\w+((-\w+)|(.\w+))@[A-Za-z0-9]+((.|-)[A-Za-z0-9]+).[A-Za-z0-9]+$/

五、分组
var reg=/((\d{3})\1/
//小括号表示分组,分组中匹配的的内容会单独保存在匹配结果中
// \1 表示调用规则中的第一组
// 1代表着后面的分组与前面括号内的特点要一致

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值