浅学正则表达式

概念:

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

应用场景:

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

相关推荐
AAA修煤气灶刘哥10 小时前
后端人速藏!数据库PD建模避坑指南
数据库·后端·mysql
程序新视界11 小时前
学习MySQL绕不开的两个基础概念:聚集索引与非聚集索引
mysql
RestCloud14 小时前
跨境数据传输:ETL如何处理时区与日期格式差异
mysql·api
RestCloud14 小时前
揭秘 CDC 技术:让数据库同步快人一步
数据库·api
得物技术18 小时前
MySQL单表为何别超2000万行?揭秘B+树与16KB页的生死博弈|得物技术
数据库·后端·mysql
xiaok18 小时前
mysql中怎么创建一个可控权限数据库账号密码给到开发者
mysql
可涵不会debug21 小时前
【IoTDB】时序数据库选型指南:工业大数据场景下的技术突围
数据库·时序数据库
ByteBlossom1 天前
MySQL 面试场景题之如何处理 BLOB 和CLOB 数据类型?
数据库·mysql·面试
玉衡子1 天前
九、MySQL配置参数优化总结
java·mysql
麦兜*1 天前
MongoDB Atlas 云数据库实战:从零搭建全球多节点集群
java·数据库·spring boot·mongodb·spring·spring cloud