位置: IT常识 - 正文
推荐整理分享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 只要匹配到符合规则的就返回断言范围类在[]组成的类内部是可以连写的
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)上一篇:【K210】K210学习笔记七——使用K210拍摄照片并在MaixHub上进行训练
下一篇:使用 Vue3 开发了四个月,回顾 emit 的用法(使用vue开发app)
友情链接: 武汉网站建设