位置: IT常识 - 正文

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

发布时间:2024-01-17
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)

  • 公司债券和企业债券哪个风险大
  • 铜川缴纳房屋契税怎么算
  • 印花税的申报依据是什么
  • 独立法人有什么风险
  • 算所得税要不要减去增值税
  • 综保区和自贸区的联系
  • 社保基数与工资不符
  • 国有企业驻外人员待遇
  • 委托加工和进口加工区别
  • 一般纳税人增值税申报操作流程
  • 营改增后房地产公司税种及税率
  • 水利行政事业性收费收入会计分录
  • 上海奉贤区控规图
  • 个人承担的社保计入管理费用吗
  • 月息和年息的换算公式等额本息
  • windows10如何设置输入法
  • 笔记本设置权限管理在哪
  • mac u盘
  • win10打开txt
  • php 输出
  • 安装win7前需要手动格式化c盘吗
  • 汽车维修行业会计分录
  • 个人之间股权转让印花税怎么交
  • 年底帐务处理
  • PHP:imagepsloadfont()的用法_GD库图像处理函数
  • 支付给员工的工伤赔偿款账务
  • 阿德莱德 景点
  • centos下file_put_contents()无法写入文件的原因及解决方法
  • 财务费用的核算属于什么业务
  • php 文件传输
  • 如何修改python
  • 前端经典面试题及答案
  • 计提票面利息
  • 织梦怎么导入数据库
  • 矿山征收
  • 季度利息收入分录
  • 合营企业和联营企业都是权益法吗
  • sqlserver2008无法连接到local用户登录失败
  • mssqlserver服务安装
  • 增值税发票相关罪名
  • 固定资产减值损失影响营业利润吗
  • 固定资产清理的含义
  • 接受母公司捐赠现金分录
  • 补缴社保的利息会进入个人账户里吗
  • 法院强制执行根本没用
  • 微信收款如何做账报税
  • 出资方式现金
  • 哪些行业不能开电子发票
  • 贸易公司的经营模式
  • 支票小写金额可以涂改吗
  • 公司给公司的工会拨款
  • sql没有数据库
  • vmware虚拟机无法打开内核设备怎么办
  • 谈一谈有关阅读的
  • windows xp自带
  • centos release6.7
  • window10升级不了
  • Ubuntu14.04 GLUT的安装
  • perl 文本文件处理
  • 怎么用unity做游戏
  • linux中unzip解压完看不到文件
  • javascript编辑工具
  • android 控件居中
  • php curl获取cookie
  • JavaScript、jQuery与Ajax的关系
  • js如何截取中文字符
  • android pipepline
  • java web开发流程
  • jquery的插件
  • 残保金申报表填写
  • 融资租赁公司购进车辆账务处理
  • 车辆购置税查询不到应征欠税信息,不能进行扣款操作
  • 百旺税控盘怎么清卡
  • 小规模纳税人企业所得税怎么征收
  • 上海川沙十八铺市场
  • 张雪峰谈建筑专业
  • 四川电子税务局网上办税大厅
  • 税务负责人
  • 一般纳税人办理退税流程及手续
  • 购买税控设备
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号