浅学正则表达式

概念:

正则表达式在程序中代表一种规则,它是一种符号语言,需要理解每一个符号表示的含义。

应用场景:

1.表单验证

2.网页信息敏感词替换

3.字符串中提取我们想要的部分

......

使用:

网址:"https://www.runoob.com/regexp/regexp-tutorial.html"

步骤:

1.定义正则:let 正则变量 = /正则要求/,//不可加引号

2.通过正则验证内容

a.正则变量.test('要被验证的内容');返回值为布尔值,true表示符合规则,false表示不符合规则

b.正则变量.exec('要被验证的内容');返回为null表示不符合规则,返回数组表示符合规则

元字符:

在正则表达式中具有特殊含义的符号(字符)

元字符分类:

边界符:

^:表示开始,以什么开始

$:表示结束,以什么结束

他们同时使用时表示精确匹配,表示当前内容,不能有其它值

量词符:

+:表示出现的次数一次或者更多次(至少出现一次)

?:表示出现的次数0次或者1次(最多1次)

*:表示出现的次数0次或多次(若干次)

{n}:表示出现的次数等于n次

{n,}:表示至少出现n次

{n,m}:表示出现n到m次

复制代码
let reg = /^ab{2}$///精确匹配,abb开头结束
let str = 'abb'
let str1 = 'aabb'
let str2 = 'abab'
console.log(reg.test(str))//true
console.log(reg.test(str1))//false
console.log(reg.test(str2))//false

字符类:

字符集:

\]:表示的含义内容中只要包含其中一个值即可 \[值-值\]:表示的含义内容中包含从某个值到某个值范围内的值即可 \[\^值\]:\[\]里面的\^表示取反 .:/./匹配除换行符之外的任何单个字符,在字符串中,如果要表示换行通过换行符实现、\\r\\n let reg = /[abc]///匹配abc中的任何单个字符 let reg1 = /[a-z]///匹配26个小写英文子母其中的任何单个字符,-表示一个范围,从某个值到某个值的范围内 let reg2 = /[a-zA-Z]///匹配大小写字母都可以 let reg3 = /[^a-z]///匹配除了26个小写英文子母之外的其它任何单个字符,^取反符号([]中括号内) let reg4 = /^[1-9][0-9]{4,}$///匹配从10000开始的所有数字 let reg5 = /^[a-zA-Z0-9_]{6,16}$///匹配6-16位英文数字下划线的内容 #### 预定义类: 指某些常见模式的简写方式,大写和小写是完全相反 ![](https://file.jishuzhan.net/article/1740279123525242881/f73b93b05484e349477cd1c6a244f1f8.webp) ## 字符串替换 ### 修饰符: 修饰符约束正则执行的某些细节行为,如是否区分大小写、是否支持多行匹配等 语法:/表达式/修饰符 i是单词ignore的缩写,正则匹配时字母不区分大小写 g是单词global的缩写,匹配所有满足正则表达式的结果 let str = 'abbcabb' let reg6 = /a/g let reg7 = /a/i ![](https://file.jishuzhan.net/article/1740279123525242881/d80b34c4fa6bb4fba11760e9fe21d0a6.webp) ### replace替换 语法:字符串.replace(/正则表达式/,'替换的文本') let str = 'abbcabb' let reg = /sb|激情/g //|表示或者的意思,就是多类替换 console.log(str.replace(reg, '**'));//abb**cab**b

相关推荐
发仔12325 分钟前
Oracle与MySQL核心差异对比
mysql·oracle
宇钶宇夕34 分钟前
EPLAN 电气制图:建立自己的部件库,添加部件-加SQL Server安装教程(三)上
运维·服务器·数据库·程序人生·自动化
爱可生开源社区1 小时前
SQLShift 重磅更新:支持 SQL Server 存储过程转换至 GaussDB!
数据库
贾修行1 小时前
SQL Server 空间函数从入门到精通:原理、实战与多数据库性能对比
数据库·sqlserver
傲祥Ax2 小时前
Redis总结
数据库·redis·redis重点总结
一屉大大大花卷2 小时前
初识Neo4j之入门介绍(一)
数据库·neo4j
叁沐3 小时前
MySQL 08 详解read view:事务到底是隔离的还是不隔离的?
mysql
周胡杰3 小时前
鸿蒙arkts使用关系型数据库,使用DB Browser for SQLite连接和查看数据库数据?使用TaskPool进行频繁数据库操作
前端·数据库·华为·harmonyos·鸿蒙·鸿蒙系统
wkj0013 小时前
navicate如何设置数据库引擎
数据库·mysql
ladymorgana3 小时前
【Spring Boot】HikariCP 连接池 YAML 配置详解
spring boot·后端·mysql·连接池·hikaricp