zl程序教程

您现在的位置是:首页 >  后端

当前栏目

JS正则表达式从入门到入土(4)—— 预定义类与边界详解编程语言

JS正则表达式入门编程语言 详解 边界 预定 入土
2023-06-13 09:20:36 时间

使用预定义类可以快速匹配目标,如:匹配一个ab+数字+任意字符,使用字符类、范围类需要书写大量的代码,而使用预定义类只需要这样写:

/ab/d/

正则表达式还提供了几个常用的边界匹配字符


当我们只想匹配一段话中中的部分单词而不是单词中的字母时,边界往往很有用

单词边界与非单词边界

有时,我想匹配一句话中的is单词,而不想匹配在单词中的is字母,此时,使用单词边界可以轻松解决这个问题:

let text = This is a boy 

let reg1 = /is/g 

let reg2 = //bis/b/g 

text.replace(reg1, IS) // 没有使用单词边界/b区分,结果为:ThIS IS a boy 

text.replace(reg2, IS) // 使用了单词边界进行区分,结果为:This IS a boy

而当我只想匹配作为单词结尾的is时,该怎么办?此时可以机智的混用单词边界与非单词边界:

let text = This is a boy 

let reg3 = //Bis/b/g 

text.replace(reg3, IS) // ThIS is a boy
^ 和 $ —— 开始与结尾

很多使用,我们会想匹配开头或结尾的字符,使用^ 和 $可以完美的解决这个问题:

let text = [email protected]@abc@ 

let reg1 = /@/g 

text2.replace(reg1, Q) // 没有使用^和$,匹配了所有的@,结果为:Q123QabcQ 

let reg2 = /^@/g 

text.replace(reg2, Q) // 使用^匹配开头的@,结果为:[email protected]@ 

let reg3 = /@$/g 

text.replace(reg3, Q) // 使用$匹配结尾的@,结果为:@[email protected]

tips:实际使用中^需要写在匹配项的前方,而$需要卸载匹配项的后方

在多行的情况下使用^和$

在多行的情况下,使用m进入多行模式才能匹配到每行的开头和结尾匹配字符:

let text = [email protected]/[email protected]/[email protected] 

let reg1 = /^@/d/g 

text.replace(reg1, Q) 

 由于换行实际上只是一个换行符字符,在正常模式下,依然看做一段字符 

 结果为: 

 Q23 

 @456 

 @789 

let reg2 = /^@/d/gm 

text.replace(reg2, Q) 

 添加了m进入多行模式: 

 结果为: 

 Q23 

 Q56 

 Q89 

*/

原创文章,作者:Maggie-Hunter,如若转载,请注明出处:https://blog.ytso.com/12250.html

cjava