正则表达式快速掌握

目录

语法

修饰符

元字符

边界符

量词

字符类

预定义

分组和捕获

分组

捕获


语法

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插件中储存有一些简单常用的正则表达式,合理利用他们能够提升开发效率

相关推荐
Rsun045512 小时前
React相关面试题
前端·react.js·前端框架
不灭锦鲤3 小时前
网络安全学习第48天
学习
Lao乾妈官方认证唯一女友:D3 小时前
通过plasmo的wallet扩展添加新钱包
javascript·web3·区块链
Javatutouhouduan3 小时前
SpringBoot整合reids:JSON序列化文件夹操作实录
java·数据库·redis·html·springboot·java编程·java程序员
ALKAOUA3 小时前
力扣面试150题刷题分享
javascript·笔记
鹏多多.3 小时前
Flutter使用screenshot进行截屏和截长图以及分享保存的全流程指南
android·前端·flutter·ios·前端框架
LawrenceLan3 小时前
37.Flutter 零基础入门(三十七):SnackBar 与提示信息 —— 页面反馈与用户交互必学
开发语言·前端·flutter·dart
怪侠_岭南一只猿3 小时前
爬虫工程师入门阶段一:基础知识点完全学习文档
css·爬虫·python·学习·html