正则

作者: 扶不起的蝌蚪 | 来源:发表于2020-04-18 16:12 被阅读0次

正则主要用于以下两种行为

  • 匹配---验证当前字符串是否符合某个规则
  • 捕获---把一个字符串中符合规则的字符获取到

创建正则的方式

  • 字面量方式
/* 
* 匹配第一个"bat"或"cat",不区分大小写
*/ 
var pattern1 = /[bc]at/i; 
  • 构造函数方式
    传递给 RegExp构造函数的两个参数都是字符串(不能把正则表达式字面量传递给RegExp 构造函数)。所以在某些情况下要对字符进行双重转义。所有元字符都必须双重转义,那些已经转义过的字符也是如此,例如\n(字符\在字符串中通常被转义为\\,而在正则表达式字符串中就会变成\\\\
/* 
* 与 pattern1 相同,只不过是使用构造函数创建的
*/ 
var pattern2 = new RegExp("[bc]at", "i"); 
字面量模式 等价的字符串
/\[bc\]at/" "\\[bc\\]at"
/\.at/" "\\.at"
/name\/age/ " "name\\/age"
/\d.\d{1,2}/ " "\\d.\\d{1,2}"
/\w\\hello\\123/ "\\w\\\\hello\\\\123"

基本参数

匹配符

简写 全称 作用
i ignoreCase 不区分大小写模式,即在确定匹配项时忽略模式与字符串的大小写
m multiline 多行模式,即在到达一行文本末尾时还会继续查找下一行中是否存在与模式匹配的项。
g global 全局模式,即模式将被应用于所有字符串,而非在发现第一个匹配项时立即停止
/* 
* 匹配字符串中所有"at"的实例
*/ 
var pattern1 = /at/g; 
/* 
* 匹配第一个"bat"或"cat",不区分大小写
*/ 
var pattern2 = /[bc]at/i; 
/* 
* 匹配所有以"at"结尾的 3 个字符的组合,不区分大小写
*/ 
var pattern3 = /.at/gi; 

元字符

简写 全称
\d 0~9之间的一个数字等价于[0-9]
\D 非0~9之间的任意字符
\w “数字、字母、下划线”中的任意一个
\s 匹配任意一个空白字符(包括\t制表符[TAB键四个空格])
\S 非空白符。
\b 匹配边界符如'zhu'(z左边和u右边就是边界) 'zhu-feng'(z左边、u右边、f左边、g右边是边界)
\n 匹配一个换行符
. 除了\n以外的任意字符
\ 转义字符(把一个普通字符转义为特殊的字符,例如:\d,把有特殊含义的转换为普通意思,例如:. 此处的点就不是任意字符,而是一个小数点)
^ 以某个元字符开头
$ 以某个元字符结尾
x|y x或者y中的任意一个
[xyz] 或者y或者z中的任意一个
[^xyz] 除了x\y\z以外的任意字符
[a-z] 获取a-z中的任意一个字符([0-9] 等价于\d ...)
[^a-z] 除了a-z的任意字符
() 正则分组
(?:) 当前分组只匹配不捕获
(?=) 正向预查
(?!) 负向预查

这些元字符在正则表达式中都有一或多种特殊用途,因此如果想要匹配字符串中包含的这些字符,就必须对它们进行转义

/* 
* 匹配第一个"bat"或"cat",不区分大小写
*/ 
var pattern1 = /[bc]at/i; 
/* 
* 匹配第一个" [bc]at",不区分大小写
*/ 
var pattern2 = /\[bc\]at/i; 
/* 
* 匹配所有以"at"结尾的 3 个字符的组合,不区分大小写
*/ 
var pattern3 = /.at/gi; 
/* 
* 匹配所有".at",不区分大小写
*/ 
var pattern4 = /\.at/gi; 


量词

简写 全称
* 出现零到多次
? 出现零到一次
+ 出现一到多次
{n} 出现N次
{n,} 出现N到多次
{n,m} 出现N到M次

方法

exec(string)

  • 返回包含第一个匹配项信息的数组;在没有匹配项的情况下返回 null
  • 返回的数组虽然是 Array 的实例,但包含两个额外的属性:indexinput。其中,index 表示匹配项在字符串中的位置,而 input 表示应用正则表达式的字符串。
  • 在数组中,第一项是与整个模式匹配的字符串,其他项是与模式中的分组匹配的字符串(如果模式中没有分组,则该数组只包含一项)。
var text = "mom and dad and baby"; 
var pattern = /mom and dad and baby/gi; 
var matches = pattern.exec(text); 
//=>["mom and dad and baby", index: 0, input: "mom and dad and baby", groups: undefined]
var text = "mom and dad and baby"; 
var pattern = /mom( and dad( and baby)?)?/gi; 
var matches = pattern.exec(text); 
console.log(matches)
//=>["mom and dad and baby", " and dad and baby", " and baby", index: 0, input: "mom and dad and baby", groups: undefined]

匹配符详解

不指定匹配符,正则默认匹配/捕获目标字符串中的第一个

var regex1 = /ab{2,5}c/
var regex2 = /ab{2,5}c/g
var string = "abc abbc abbbc abbbbc abbbbbc abbbbbbc";
console.log( string.match(regex1) );
//=>["abbc", index: 4, input: "abc abbc abbbc abbbbc abbbbbc abbbbbbc", groups: undefined]
console.log( string.match(regex2) );
//=>["abbc", "abbbc", "abbbbc", "abbbbbc"]

g匹配具有贪婪性

var regex = /\d{2,5}/g;
var string = "123 1234 12345 123456";
console.log( string.match(regex) ); 
// => ["123", "1234", "12345", "12345"]

//正则/\d{2,5}/,表示数字连续出现2到5次。会匹配2位、3位、4位、5位连续数字。

常见正则

精确匹配

var regex = /hello/
console.log( regex.test("aaahello11") );

匹配电话号码

let reg = /^1\d{10}$/  //以1开头的11位数字

相关文章

  • java正则使用

    正则切割 正则捕获 正则完全匹配

  • regexp 正则包

    正则对象 正则使用都是通过创建对应的正则对象,调用对象方法所实现。 新建正则对象 正则对象属性方法 正则方法 一般...

  • 个人书画作品之四

    写楷心得 字正则心正,心正则人正,人正则德正,德正则身正, 身正则形正,形正则意正, 意正则气正,一气化三清。 ...

  • 第七天正则表达式

    正则表达式的理念: 正则的使用方法: 正则里string两个方法: 使用正则找字母的几种写法: 正则的转义: 正则...

  • 心正笔正

    心正则意正!心正则身正! 心正则言正!心正则行正! 心正则笔正!心正则字正! 心正则并勤!勤尽则字成! 心清则目明...

  • git一次删除多个文件

    正则 非正则

  • day17-正则表达式

    正则表达式符号含义 通配符与正则区别? 正则表达式中注意事项 正则表达式分类: 基本正则(BRE) ※ 扩展正则表...

  • Js正则匹配常用案例

    1 用户名正则 2 密码强度正则 3 整数正则 4 数字正则 5 Email正则 6 手机号码正则 7 身份证号正...

  • 前端表单验证常用的15个JS正则表达式

    1.用户名正则 2 密码强度正则 3 整数正则 4 数字正则 5 Email正则 6 手机号码正则 7 身份证号正...

  • 2019-06-15 JS

    email正则, url正则

网友评论

      本文标题:正则

      本文链接:https://www.haomeiwen.com/subject/riavvhtx.html