js 正则使用笔记

简介: js 正则使用笔记

目录



场景



有时候写正则时很混乱可能是没有分清楚自己写正则的场景。


一般js使用正则,两个场景:


需要知道某一个字符串是否达到我们需要的形式。(我们关心的是字符串)

需要获取某一个字符串中匹配到的内容,或者是否匹配到内容。(我们关心的是正则内容)

解决方式:


exp.test(str)

str.match(exp)

test



记住一点,test在匹配时我们需要对一整个字符串进行匹配,所以在写正则时形式一定是有头有尾/^...$/。

例子:检测字符串是不是纯数字


错误

    //正则没有头尾,我们发现只要是字符串存在数字它就返回true,目的就变成检测是否含有数字了,成了场景2
    const exp = /\d+/;
    console.log(exp.test('aaa123'))//true
    console.log(exp.test('123'))//true

正确

    const exp = /^\d+$/;
    console.log(exp.test('aaa123'))//false    
    console.log(exp.test('123'))//true

match


match来判断是否存在我们要的内容。

例子1:检测字符串中有没有数字、获取字符串中的数字。


代码1

    const exp = /\d+/;
    console.log(Boolean('123aa56'.match(exp)), '123aa56'.match(exp))

结果:我们发现我们检测是对了,但是没有匹配到56


代码2

    const exp = /\d+/g;
    console.log(Boolean('123aa56'.match(exp)), '123aa56'.match(exp))

结果:加上/g就会找到所有匹配上的内容了

image.png

另外,零宽断言也在匹配中很常用,比如匹配小数点后的数字,你需要用到小数点来查,但是你不需要获取小数点/(?<=\.)(\d+)/g,浅记一下。

相关文章
|
5天前
|
JavaScript 前端开发
JavaScript随手笔记 --- 对数据进行判断最大位数是否超过八位
JavaScript随手笔记 --- 对数据进行判断最大位数是否超过八位
|
5天前
|
JavaScript 前端开发
JavaScript随手笔记 --- 用正则表达式匹配字符串是否为运算公式
JavaScript随手笔记 --- 用正则表达式匹配字符串是否为运算公式
|
3天前
|
JavaScript 前端开发
JS中正则方法的使用 - 蓝易云
以上就是JavaScript中正则方法的基本使用。这些方法可以用于执行复杂的字符串处理和验证任务。
19 1
|
5天前
|
JavaScript 前端开发 Java
JavaScript高级笔记-coderwhy版本(六)
JavaScript高级笔记-coderwhy版本
75 0
|
5天前
|
JavaScript 前端开发 Java
JavaScript高级笔记-coderwhy版本(一)
JavaScript高级笔记-coderwhy版本
35 0
JavaScript高级笔记-coderwhy版本(一)
|
5天前
|
JSON JavaScript 前端开发
Node.JS第二讲笔记
Node.JS第二讲笔记
33 0
|
5天前
|
JavaScript 前端开发 索引
JavaScript随手笔记---对比数组差异
JavaScript随手笔记---对比数组差异
JavaScript随手笔记---对比数组差异
|
5天前
|
JavaScript 前端开发
JavaScript随手笔记---轮播图(点击切换)
JavaScript随手笔记---轮播图(点击切换)
JavaScript随手笔记---轮播图(点击切换)
|
5天前
|
JSON JavaScript 前端开发
JavaScript随手笔记---数组中相同的元素进行分组(数据聚合) groupBy函数
JavaScript随手笔记---数组中相同的元素进行分组(数据聚合) groupBy函数
|
5天前
|
JavaScript 前端开发
JavaScript随手笔记---保留小数位
JavaScript随手笔记---保留小数位