位置: IT常识 - 正文

JS——正则表达式(超详细)(js正则用法)

编辑:rootadmin
JS——正则表达式(超详细) 正则表达式概念创建正则表达式正则表达式常用方法test(字符串)search(正则表达式)正则表达式.exec(字符串)字符串.match(正则表达式)字符串.replace(正则表达式,新的内容)断言范围类字符类字符类取反修饰符g:global全文搜索i:ignore case 忽略大小写m:multiple lines 多行搜索其他标志符量词符贪婪模式非贪婪模式分组反向引用概念

推荐整理分享JS——正则表达式(超详细)(js正则用法),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js正则 \w,js正则用法,js正则用法,js正则表达式/g,js正则表达式\d,js正则 \w,js中正则表达式语法,js正则表达式,内容如对您有帮助,希望把文章链接给更多的朋友!

正则表达式是用于匹配字符串中字符组合的模式。在 JavaScript中,正则表达式也是对象。这些模式被用于 RegExp 的 exec 和 test 方法, 以及 String 的 match、matchAll、replace、search 和 split 方法。

创建正则表达式

两种方法:字面量方式、构造函数方式

//字面量方式,其由包含在斜杠之间的模式组成,如下所示:var re = /ab+c/;//构造函数方式,调用RegExp对象的构造函数,如下所示:var re = new RegExp("ab+c");正则表达式常用方法校验数据test(字符串)

测试字符是否满足正则表达式规则,如果测试到有,则返回true;没有则返回flase 语法:正则表达式.test(字符串) 正则表达式提供的方法

var reg=/[123]/var str='1'var result=reg.test(str)console.log(result)//flasesearch(正则表达式)

search() 方法执行正则表达式和 String 对象之间的一个搜索匹配。 语法:字符串.search(正则表达式) 字符串提供的方法

var reg=/\d/ //匹配阿拉伯数字var str="abcdefg3sgbh"var res=str.search(reg) console.log(res) //7//验证方法 找到返回下标 找不到返回-1//在字符串中找到满足正则表达式的那一部分区别:.test()方法是正则表达式提供的,.search()是字符串提高的,.test()方法返回布尔值,search()返回下标提取数据正则表达式.exec(字符串)

exec() 方法在一个指定字符串中执行一个搜索匹配。返回一个结果数组或 null。 正则表达式提供的方法

var reg=/\d/var str="abcd456efg"var res=reg.exec(str)console.log(res)//返回一个数组,内容是4//字符串中满足正则表达式的部分提取出来//遇到满足条件的就返回,所以只返回4字符串.match(正则表达式)

match() 方法检索返回一个字符串匹配正则表达式的结果。 字符串提供的方法

var reg=/\d/var str="abcd456efg"var res=str.match(reg) //字符串中满足表达式的部分提取出来console.log(res) 区别:正则表达式.exec(字符串),正则表达式提供的方法字符串.match(正则表达式) 字符串的方法相同:都返回一个数组,只要匹配到符合规则的数据就返回替换数据字符串.replace(正则表达式,新的内容)

replace() 方法返回一个由替换值(replacement)替换部分或所有的模式(pattern)匹配项后的新字符串。模式可以是一个字符串或者一个正则表达式,替换值可以是一个字符串或者一个每次匹配都要调用的回调函数。如果pattern是字符串,则仅替换第一个匹配项。字符串提供的方法

var reg=/\d/var str="11123bcd"var res=str.replace(reg,"a") //将数字换为aconsole.log(res)//a1123bcd 只要匹配到符合规则的就返回断言

范围类JS——正则表达式(超详细)(js正则用法)

在[]组成的类内部是可以连写的

let text = 'a1B2d3X4Z5'let reg=/[a-zA-Z]/text.replace(reg,'Q')//Q1Q3Q4Q5字符类

字符类取反

很多时候碰到这么一种情况,即不想匹配某些字符,其他都匹配。此时,可以使用字符类取反——使用元字符^,创建反向类,即不属于某类的内容。

[abc]表示不是字符a或b或c的内容let reg=/[^abc]/glet text='a1b2c3d4e5'console.log(text.replace(reg,'X')) //输出aXbXcXdXeX修饰符

在正常情况下,正则匹配到第一个匹配项则停止,并且默认大小写敏感,如果想修改默认选项,则需要修饰符。

g:global全文搜索var reg=new RegExp('l');var a='hello'.replace(reg,'f')console.log(a)//输出结果为:heflovar reg=new RegExp('l','g');//加上g标签表示全文搜索var a='hello'.replace(reg,'f')console.log(a)//输出结果为:heffo (所有的 l 都换成了 f )i:ignore case 忽略大小写var reg=new RegExp('l','g');var a='helloHELLO'.replace(reg,'f')console.log(a)//输出结果为:heffoHELLOvar reg=new RegExp('l','gi');//加上i标签表示忽略大小写var a='helloHELLO'.replace(reg,'f')console.log(a)//输出结果为:heffoHEffO (大写和小写的l都被替换了)m:multiple lines 多行搜索var reg=new RegExp('od')var str='so good\n so good'var result=str.replace(reg,'hi')console.log(result)//结果为: so gohi so good //只给第一行匹配了var reg=new RegExp('od','gm')//加上m标签表示多行匹配var str='so good\n so good'var result=str.replace(reg,'hi')console.log(result)//结果为: so gohi so gohi 其他标志符

s:允许 . 匹配换行符。 u:使用unicode码的模式进行匹配。 y:执行“粘性(sticky)”搜索,匹配从目标字符串的当前位置开始。

量词符

贪婪模式

之前说了正则表达式的量词,但量词会带来一个到底匹配哪个的问题 例如:

var str="12345678"var reg=/\d{3,6}/gstr.replace(reg,'X') //X78

可以看到结果是将123456 六个数字替换成了X,所以我们可以得到,正常模式下,正则表达式会尽可能多的匹配。正常情况下,正则表达式采用贪婪模式,即,尽可能多的匹配。

非贪婪模式

一但成功匹配不再继续尝试,这就是非贪婪模式。 只需要在量词后加上?即可

var str="12345678"var reg=/\d{3,6}?/gstr.replace(reg,'X') //X45678分组

在使用正则表达式的时候会想要匹配一串字符串连续出现多次的情况,使用()可以达到分组的功能 例如:(hello){3} 使用符号 | (或)实现选择的功能 例如:

var str='12341235'let reg=/123(4|5)/g//1234 1235二选一反向引用

将一种格式的时间字符串:yyyy-MM-DD转为MM/DD/yyyy类型格式字符串。 由于年月日是不固定的,没法直接转换为固定数值。这时我们可以使用反向引用解决这个问题。 利用$n,n代表着分组的序号,序号是从1开始的。

例如:

let text='2022-02-23'let reg=/(\d{4})-(\d{2})-(\d{2})/let res=text.replace(reg,'$3/$2/$1')//将yyyy-MM-DD转换为MM/DD/yyyyconsole.log(res)
本文链接地址:https://www.jiuchutong.com/zhishi/300758.html 转载请保留说明!

上一篇:【K210】K210学习笔记七——使用K210拍摄照片并在MaixHub上进行训练

下一篇:使用 Vue3 开发了四个月,回顾 emit 的用法(使用vue开发app)

  • 财税201920号文件解读
  • 企业间无偿划转资产,非关联方经营
  • 本期准予抵减税额怎么算
  • 销售自己使用过的物品
  • 来料加工企业的人工工资计入什么费用
  • 不应抵扣的进项税抵扣了怎么办
  • 个体户能不能去注销
  • 收到销项负数发票怎么处理
  • 外贸 内销
  • 金融业保险业
  • 盈余公积可以发放工资吗
  • 打印企业银行流水需要密码吗
  • 二手房个人所得税和增值税
  • 本年利润年末账务处理
  • 企业的污水处理设备可以间断性运行么
  • 公司买别人汇票有风险吗
  • 固定资产可以一次折旧完吗
  • 服务业成本会计分析
  • windows刷新桌面
  • mac软件打开提示意外退出
  • window10总是自动开机
  • 进程 com surrogate
  • 微信用不升级
  • thinkphp5数据库操作
  • 营业税改增值税的过程
  • php操作json文件
  • 金税三期个税扣缴客户端
  • 物流公司交保险是骗局吗
  • 不想预缴所得税能不能提前暂估费用,会计分录
  • 错误解决方法
  • 小规模纳税人采购零配件税率
  • 红字更正法和红字冲销的区别
  • 公路修路步骤
  • 不同情况不同处理的句子
  • 接待客人发生的事故
  • 外包食堂可以开专票吗
  • 预付账款的适用范围
  • 燃油税税率是多少
  • 劳务派遣工资的发放单位
  • 软件研发主要研发啥软件
  • 快递收据能报销吗
  • 消防设备计入什么科目
  • 对公转账需要填备注吗
  • 管理费用科目包括
  • 无形资产多摊销怎么处理
  • 实收资本核算内容是什么
  • 公司账户钱能全取出来吗
  • 销售货物增值税税率变化
  • 营业外收入的核算内容
  • 交所得税的分录
  • 会计凭证编制程序和用途
  • 运费未付的会计分录怎么做
  • 工程项目分包需要招标吗
  • mysql 5.7.34安装
  • sql语句的查询语句
  • select * from sp_who的解决方案
  • mysql5.5解压版安装教程
  • windows内存诊断是干什么的
  • 如何卸载独显
  • ntfs跟fat32
  • Windows server 2008设置远程桌面连接的详细步骤(图文教程)
  • iphone制造成本
  • xp系统下载文件没有出现下载对话框让你选择保存的位置
  • centos哪个版本最好用2022
  • windows8任务管理器在哪
  • muamgr.exe - muamgr是什么进程 有何作用
  • Windows7如何查看电脑配置
  • Win7系统打开D盘文件后怎么没有后退箭头
  • el-menu-item
  • ExtJS4给Combobox设置列表中的默认值示例
  • 全志科技在国内芯片界地位
  • perl脚本输出变量
  • unity热更新一般更新什么
  • jquery使用jsonp
  • 定时软件有哪些
  • js表单事件有哪些
  • python怎么写爬虫
  • python+Django+apache的配置方法详解
  • 工会经费计提比例0.8%
  • 金米财税口碑如何?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设