正则表达式快速掌握

目录

语法

修饰符

元字符

边界符

量词

字符类

预定义

分组和捕获

分组

捕获


语法

test(),查看正则表达式与指定的字符串是否匹配

javascript 复制代码
    const reg =/前端/
    // test(),查看正则表达式与指定的字符串是否匹配
    const res = reg.test('学前端,找黑马')//匹配到返回true,匹配不到返回false
    console.log(res);

exec(),查找符合规则的字符串

javascript 复制代码
const reg =/前端/
    // exec(),查找符合规则的字符串
    const res = reg.exec('学前端,找黑马')
    console.log(res);

replace(),用来替换字符串中符合规则的字符

javascript 复制代码
    const reg =/前端/
    // replace(),用来替换字符串中符合规则的字符
    const str = '学前端,找黑马'
    const res = str.replace(reg,'java')
    console.log(res);//可以用于敏感词替换

match(),在字符串内检索指定的值,或找到一个或多个正则表达式的匹配

javascript 复制代码
    const reg =/前端/
 // match(),在字符串内检索指定的值,或找到一个或多个正则表达式的匹配
    const str = '学前端,找黑马'
    console.log(str.match(reg));

修饰符

i:ignore的缩写,正则匹配时字母不区分大小写

javascript 复制代码
    //i:ignore的缩写,正则匹配时字母不区分大小写
    const reg =/a/
    console.log(reg.test('a'));//true
    console.log(reg.test('A'));//false
    const reg =/a/i
    console.log(reg.test('a'));//true
    console.log(reg.test('A'));//true

g:单词global的缩写,匹配所有满足正则表达式的结果

javascript 复制代码
 //g:单词global的缩写,匹配所有满足正则表达式的结果
    const reg =/java/g
    const str ='java,我爱java,我喜欢java'
    console.log(str.replace(reg,'前端'))

修饰符可以写多个,且不分顺序

javascript 复制代码
//     可以写多个修饰符
    const reg =/java/gi//不分顺序

元字符

边界符

单词边界 \b

javascript 复制代码
  //单词边界 \b
    const reg =/\bcat\b/g
    const str ='the cate cat is blue'
    console.log(str.replace(reg,'dog'))

字符串边界 ^ $

javascript 复制代码
  //字符串边界 ^  $
    //^以......开头
    const reg = /^a/
    console.log(reg.test('abc'));//true
    //$以......结尾
    const reg = /a$/
    console.log(reg.test('bca'));//true
    const reg = /^a$///表示精确匹配
    console.log(reg.test('abca'));//false

量词

*表示0或更多次

javascript 复制代码
 const reg = /^a*$/
    console.log(reg.test('aaa'));//true
    console.log(reg.test(''));//true
    console.log(reg.test('b'));//false

+表示1或更多次

javascript 复制代码
   const reg = /^a+$/
    console.log(reg.test('aaa'));//true
    console.log(reg.test(''));//false
    console.log(reg.test('b'));//false

?:表示0次或1次

javascript 复制代码
    const reg = /^a?$/
    console.log(reg.test('aaa'));//false
    console.log(reg.test(''));//true
    console.log(reg.test('b'));//false

{n}表示只能有n次

javascript 复制代码
  const reg = /^a{3}$/
    console.log(reg.test('aaa'));//true
    console.log(reg.test(''));//false
    console.log(reg.test('b'));//false

{n,}表示大于等于n次

javascript 复制代码
 const reg = /^a{3,}$/
    console.log(reg.test('aaa'));//true
    console.log(reg.test('aaaaa'));//true
    console.log(reg.test('b'));//false

{n,m}表示n次到m次

javascript 复制代码
 const reg = /^a{3,10}$/
    console.log(reg.test('aaa'));//true
    console.log(reg.test('aaaaa'));//true
    console.log(reg.test('b'));//false

字符类

\[\]:匹配\[\]中任意一个

javascript 复制代码
  const reg =/[abc]/ //匹配abc中任意一个
    console.log(reg.test('abc'));//true
    console.log(reg.test('andy'));//true

-:表示范围

javascript 复制代码
 const reg =/[a-z]/
    const reg = /[A-Z]/
    const reg = /[0-9]/
    const reg = /[a-zA-Z0-9_]/

^:取反

javascript 复制代码
 const reg =/[^abc]/ //abc之外的任意东西

.:匹配除换行之外的任意字符

javascript 复制代码
    const reg = /./

预定义

javascript 复制代码
 const  reg1 =/\d/ //const reg = /[0-9]/
    const  reg1 =/\D/ //const reg = /[^0-9]/
    const  reg1 =/\w/ //const reg = /[a-zA-Z0-9_]/
    const  reg1 =/\W/ //const reg = /[^a-zA-Z0-9_]/
    const  reg1 =/\s/ //const reg =/[/t/r/n/v/f]/
    const  reg1 =/\S/ //const reg =/[^/t/r/n/v/f]/

分组和捕获

分组

javascript 复制代码
 const reg =/(ab)+/ //ab
    console.log(reg.test('ab'));//true
    console.log(reg.test('abab'));//true

捕获

javascript 复制代码
 //分组捕获
    //例如将yyyy-mm-dd格式换成mm/dd/yy
    const reg = /^(\d{4})-(\d{2})-(\d{2})$/
    const date = '2023-01-05'
    // console.log(reg.test(date));
    console.log(date.replace(reg,'$2/$3/$1'));

vscode中any-rule插件中储存有一些简单常用的正则表达式,合理利用他们能够提升开发效率

相关推荐
默_笙2 分钟前
🎄 后端给我一堆扁平数据,我 10 行代码把它变成了树
前端·javascript
Mahut4 分钟前
我用 Electron + FFmpeg 做了一个本地视频处理工作站 ClipForge
前端·ffmpeg·electron
前端Hardy7 分钟前
又一个 AI 神器火了!
前端·javascript·后端
锋行天下12 分钟前
我试图优化 Vite 的拆包,结果首屏慢了 10 倍
前端·vue.js·架构
PBitW30 分钟前
GPT训练我的第二天,我表示不过如此!!!😕😕😕
前端·javascript·面试
用户990450177800943 分钟前
学习了AI修图,我把自己闲鱼出租房照片整成airbnb风格了
前端
kyriewen2 小时前
白宫直接给 OpenAI 下了限制令,GPT-5.6 不能随便放出来了
前端·javascript·面试
PedroQue993 小时前
Vite插件v0.2.6:架构优化与自动化升级
前端·vite
threerocks4 小时前
什么?我连 A2A、MCP 都没学会,现在又来了 AG-UI、A2UI.
前端·aigc·ai编程
牛奶5 小时前
如何自己写一个浏览器插件?
前端·chrome·浏览器