JS正则基础整理

Regular Expression 正则表达式是指:

使用单个字符串来描述或者匹配一系列符合某个句法规则的字符串。

在JS中正则有两种表达方式:

1. 字面量 var reg = /\b$/g

2. 构造函数 var reg = new RegExp('\\b$','g')

上面字面量或者构造函数中包含的g为正则表达式中的修饰符,修饰符包括:

1. g:global代表全文搜索,不添加,则匹配到第一个之后就停止

2. i:ignore case代表忽略大小写,默认对大小写敏感

3. m:multiple lines代表多行搜索

接下来介绍正则中比较特殊的字符:

\t 水平制表符

\v 垂直制表符

\n 换行符

\r 回车符

\0 空字符

\f 换页符

\cX 与X对应的控制字符 e.g. Ctrl+X

接下来我们来看正则表达式怎么书写,一般情况下

正则表达式的一个字符对应字符串中的一个字符

abc\t 

表示字符abc再加上一个水平制表符

abc\t

[abc]\t

[]代表类,类表示泛指,所以表达式表示abc中任意一个,再加一个水平制表符

[abc]\t

[^abc]\t

对于类,我们是可以通过^取反的,所以表达式表示不是abc中任意一个,再加一个水平制表符

[^abc]\t

[a-z]

如果我们要创建一个24个小写字母的类,依据上面的方法,我们可以把24个字母都写到[]中,但这样很冗杂,所以就有了范围类,所以表达式表示a到z中任意一个小写字母,包含a和z

[a-z]

有一些常用的类被预先定义了,称为预定义类,用起来比较方便

字符 | 等价类 | 含义

.  [^\n\r] 除了回车和换行符以外的所有字符

\d  [0-9] 数字字符

\D  [^0-9] 非数字字符

\s  [\t\n\x0B\f\r] 空白符

\S  [^\t\n\x0B\f\r] 非空白符

\w  [a-zA-Z_0-9] 单词字符,包括:字母、数字、下划线

\W  [^a-zA-Z_0-9] 非单词字符

[abc]\d

表示匹配abc中任意一个,再加一个数字

[abc]\d

上面的举例都是一个字符一个字符的匹配,万一需要匹配的字符串很长,比如说需要连续出现10个数字字符,那我们应该怎样去写比较方便呢?

\d{10}

表示数字出现10次

\d{10}

像这样的量词,正则中有如下规定:

字符 | 含义

?  出现一次或没有,最多一次

+  出现一次或更多,至少一次

*  没有或出现多次,出现任意次

{n}  出现n次

{n,m}  出现n到m次

{n,}  至少出现n次

abc\b

表示abc后面匹配一个位置,这个位置为单词边界,所谓单词边界指:一个位置,这个位置的一侧是构成单词的字符,另一侧为非单词字符、字符串的开始或结束位置。“\b”是零宽度的。

abc\b

正则还提供了一些边界匹配字符

字符 | 含义

^  以xxx开始

$  以xxx结尾

\b  单词边界

\B  非单词边界

学会了书写,接下来我们来看匹配,匹配有贪婪模式匹配,和非贪婪模式匹配,非贪婪模式指让正则表达式尽可能的少匹配,一旦匹配成功就不再继续尝试匹配,而贪婪模式刚好相反

要实现非贪婪模式匹配,就在两次后面加上?就可以了

非贪婪模式和贪婪模式

abc{3}

abc{3}

(abc){3}

(abc){3}

使用()可以进行分组

wendy(S|Q)

wendy(S|Q)

可以使用|代表或者的意思

JS中用的比较多的方法在这儿列举一下:

reg.test('123') 如果符合规则返回true,否则返回false

'123'.match(/\d{1,2}/g) 返回匹配到的结果,若有则为数组,否则为null

'2017-10-07'.replace(/(\d{4})-(\d{2})-(\d{2})/g,'$2'+'-'+'$3'+'-'+'$1')

replace方法

若是不想捕获某一个分组,可以在分组加上?: 即可

replace不捕获某一分组

最后,推荐一个正则表达式的分析工具https://regexper.com/#wendy(S%7CQ)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,367评论 6 512
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,959评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,750评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,226评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,252评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,975评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,592评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,497评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,027评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,147评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,274评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,953评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,623评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,143评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,260评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,607评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,271评论 2 358

推荐阅读更多精彩内容