正则表达式

一个有用的在线工具 https://regexper.com/

一、元字符

  1. 创建方法

字面量:
var 变量名 = /表达式/模式匹配符

var e = /\bare\b/

构造函数
var 变量名 = new RegExp ("表达式", "模式匹配符")

var e = new RegExp('\\bare\\b');
  1. 单个的字符与数字
元字符 描述
. 匹配除换行符外的任意字符
[az09] 匹配方括号中的任意字符
[^az09] 匹配不在方括号中的任意字符
\d 匹配一个数字字符,等价于[0-9]
\D 匹配任意一个不是基本拉丁字母表中数字的字符。等价于[^0-9]
\w 匹配字母
\W 匹配非字母
  1. 空白字符
元字符 描述
\0 匹配空字符
[\b] 匹配空格符
\f 匹配换页符
\n 匹配换行符
\r 匹配回车符
\s 匹配空白符、空格、制表符和换行符
\S 匹配非空白字符
\t 匹配制表符
  1. 量词
元字符 描述
+ 匹配一个或者多个字符
* 匹配零个或者更多字符
? 匹配零个或者一个字符,为了能够匹配" ? ",需要进行转?
{ n } 匹配 n 次
{ n, } 至少匹配 n 次
{ 2,4 } 匹配 2 到 4 次

*+都是贪婪匹配,匹配时总是寻找最大的匹配,而不是最小的。
*?*的非贪婪版本
*?*的非贪婪版本

  1. 定位符
元字符 描述
^ 字符串的开始
$ 字符串的结束
(?m) 使用多行模式

注意:如果使用多行模式的话,(?m)必须放置在正则表达式的开始。

二、方法

(一)实例方法

  1. exec()

在字符串中进行匹配检索,返回找到的值,并确定其位置

RegExpObject.exec(string)

var IS_CHINA_UNION = /^(?:13[0-2]|145|146|15[56]|171|18[56])\d{7,8}$/; 
IS_CHINA_UNION .exec('15600000000')  
// 返回一个数组,["15600000000", index: 0, input: "15647251102", groups: undefined]
// 如果去掉上面正则括号中的?:
// 会返回 ["15600000000", "156", index: 0, input: "15647251102", groups: undefined]
// 不加?:表示对正则进行了分组
  1. test()

在字符串中测试模式匹配,返回truefalse

RegExpObject.test(string)

(二)字符串方法

  1. match()

找到一个或多个正则表达式的匹配

var strMatch = "hello world,hello world";
strMatch.match("world"));    // ["world", index: 6, input: "hello world,hello world"]
strMatch.match(/world/g));    // ["world", "world"]
  1. replace()

替换与正则表达式匹配的子串

var strReplace = "hello world,hello world";
 //替换字符串
 var s1 = strReplace.replace("hello","a");
 s1;    //a world,hello world
 //使用正则替换字符串
 var s2 = strReplace.replace(/hello/,"a");
 s2;    //a world,hello world
 var s3 = strReplace.replace(/hello/g,"a");
 s3;    //a world,a world
  1. search()

检索与正则表达式相匹配的值

var strSearch = "hello world,hello world";
strSearch.search('wo');      //6
  1. split()

把字符串分割为字符串数组

 var strSplit = "what are you doing?";
 //以" "分割字符串
 console.log(strSplit.split(" "));                   
 //["what", "are", "you", "doing?"]
 //以""分割
 console.log(strSplit.split(""));                    
 //["w", "h", "a", "t", " ", "a", "r", "e", " ", "y", "o", "u", " ", "d", "o", "i", "n", "g", "?"]
 console.log(strSplit.split("",3));                 
 //["w", "h", "a"]

三、例子

常用的几个例子:

邮箱:^[a-zA-Z0-9]{4,}@[a-z0-9A-Z]{2,}\\.[a-zA-Z]{2,}$

手机号码:^((13[0-9])|(15[^4\\D])|(18[0,2,5-9]))\\d{8}$

大陆固定电话号码:^\\d{4}-|\\d{3}-)?(\\d{8}|\\d{7}$

身份证号:\\d{14}[[0-9],0-9xX]

Email地址:^\\w+([-+.]\\w+)*@\\w+([-.]\\w+)*\.\\w+([-.]\\w+)*$

纯数字:^[0-9]*$

由数字和英文字母组成:^[A-Za-z0-9]+$

QQ号:^[1-9][0-9]\{4,\}$

中国邮政编码:^[1-9]\\d{5}(?!\\d)$

URL:^http(s)?://([\\w-]+\\.)+[\\w-]+(/[\\w- ./?%&=]*)?$

纯汉字:^[\u4e00-\u9fa5]{0,}$

参考例子:

1.验证用户名和密码:”^[a-zA-Z]\w{5,15}$”

2.验证电话号码:(”^(\d{3,4}-)\d{7,8}$”)

eg:021-68686868 0511-6868686;

3.验证手机号码:”^1[3|4|5|7|8][0-9]\d{8}$”;

4.验证身份证号(15位或18位数字):”\d{14}[[0-9],0-9xX]”;

5.验证Email地址:(“^\w+([-+.]\w+)@\w+([-.]\w+).\w+([-.]\w+)*$”);

6.只能输入由数字和26个英文字母组成的字符串:(“^[A-Za-z0-9]+$”) ;

7.整数或者小数:^[0-9]+([.]{0,1}[0-9]+){0,1}$

8.只能输入数字:”^[0-9]*$”。

9.只能输入n位的数字:”^\d{n}$”。

10.只能输入至少n位的数字:”^\d{n,}$”。

11.只能输入m~n位的数字:”^\d{m,n}$”。

12.只能输入零和非零开头的数字:”^(0|[1-9][0-9]*)$”。

13.只能输入有两位小数的正实数:”^[0-9]+(.[0-9]{2})?$”。

14.只能输入有1~3位小数的正实数:”^[0-9]+(.[0-9]{1,3})?$”。

15.只能输入非零的正整数:”^+?[1-9][0-9]*$”。

16.只能输入非零的负整数:”^-[1-9][]0-9″*$。

17.只能输入长度为3的字符:”^.{3}$”。

18.只能输入由26个英文字母组成的字符串:”^[A-Za-z]+$”。

19.只能输入由26个大写英文字母组成的字符串:”^[A-Z]+$”。

20.只能输入由26个小写英文字母组成的字符串:”^[a-z]+$”。

21.验证是否含有^%&’,;=?\”等字符:”[^%&’,;=?\x22]+”。

22.只能输入汉字:”^[\u4e00-\u9fa5]{0,}$”。

23.验证URL:”^http://([\w-]+.)+[\w-]+(/[\w-./?%&=]*)?$”。

24.验证一年的12个月:”^(0?[1-9]|1[0-2])$”正确格式为:”01″~”09″和”10″~”12″。

25.验证一个月的31天:”^((0?[1-9])|((1|2)[0-9])|30|31)$”正确格式为;”01″~”09″、”10″~”29″和“30”~“31”。

26.获取日期正则表达式:\d{4}[年|-|.]\d{\1-\12}[月|-|.]\d{\1-\31}日?

评注:可用来匹配大多数年月日信息。

27.匹配双字节字符(包括汉字在内):[^\x00-\xff]

评注:可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)

28.匹配空白行的正则表达式:\n\s*\r

评注:可以用来删除空白行

29.匹配HTML标记的正则表达式:<(\S?)[^>]>.?|<.? />

评注:网上流传的版本太糟糕,上面这个也仅仅能匹配部分,对于复杂的嵌套标记依旧无能为力

30.匹配首尾空白字符的正则表达式:^\s|\s$

评注:可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式

31.匹配网址URL的正则表达式:[a-zA-z]+://[^\s]*

评注:网上流传的版本功能很有限,上面这个基本可以满足需求

32.匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$

评注:表单验证时很实用

33.匹配腾讯QQ号:[1-9][0-9]{4,}

评注:腾讯QQ号从10 000 开始

34.匹配中国邮政编码:[1-9]\d{5}(?!\d)

评注:中国邮政编码为6位数字

35.匹配ip地址:((2[0-4]\d|25[0-5]|[01]?\d\d?).){3}(2[0-4]\d|25[0-5]|[01]?\d\d?)。

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

推荐阅读更多精彩内容