正则表达式快速掌握

目录

语法

修饰符

元字符

边界符

量词

字符类

预定义

分组和捕获

分组

捕获


语法

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]/ ``` ### 分组和捕获 ![](https://i-blog.csdnimg.cn/direct/93b0e8abd04c4084a1d9e73c6872a121.png) #### 分组 ```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插件中储存有一些简单常用的正则表达式,合理利用他们能够提升开发效率

相关推荐
里欧跑得慢15 小时前
17. Flutter Hero动画实现:让界面过渡更加优雅
前端·css·flutter·web
北顾笙98016 小时前
LLM学习-day04
学习
IT_陈寒16 小时前
Vue的这个响应式陷阱,我debug了一整天才爬出来
前端·人工智能·后端
cn_mengbei16 小时前
用React Native开发OpenHarmony应用:Reanimated共享元素过渡
javascript·react native·react.js
kyriewen16 小时前
前端测试:别为了100%覆盖率而写测试,那是自欺欺人
前端·javascript·单元测试
去伪存真16 小时前
我自己写的第一个skills--project-core-standards
前端·agent
Data_Journal17 小时前
如何使用cURL更改User Agent
大数据·服务器·前端·javascript·数据库
掌心向暖RPA自动化17 小时前
如何获取网页某个元素在屏幕可见部分的中心坐标影刀RPA懒加载坐标定位技巧
java·javascript·自动化·rpa·影刀rpa
竹林81817 小时前
wagmi v2 多链钱包切换:一个 Uniswap 仿盘项目让我踩了三天坑
前端·javascript
donecoding17 小时前
Playwright MCP 页面捕获:Snapshot、截图、HTML 到底选哪个?
前端·ai编程·前端工程化