引用类型:在 ECMAScript 中,它是一种数据结构,用于将数据和功能组织在一起。
RegExp 类型(ECMAScript 通过 RegExp 类型来支持正则表达式。)
-
以字面量形式来定义正则表达式
语法: var expression = / pattern / flags ; //创建一个正则表达式。
模式( pattern)部分:任何简单或复杂的正则表达式,可以包含字符类、限定符、分组、向前查找以及反向引用。
标志(flags)部分:每个正则表达式都可带有一或多个标志,用以标明正则表达式的行为。
正则表达式的匹配模式支持下列 3 个标志:- g:全局( global)模式,即模式将被应用于所有字符串,而非在发现第一个匹配项时立即停止
- i:不区分大小写( case-insensitive)模式,即在确定匹配项时忽略模式与字符串的大小写
- m:多行( multiline)模式,即在到达一行文本末尾时还会继续查找下一行中是否存在与模式匹配的项
-
使用RegExp 构造函数创建正则表达式
语法: var expression=new RegExp(pattern,flags)
接收两个参数:一个是要匹配的字符串模式,另一个是可选的标志字符串。
注:传递给 RegExp 构造函数的两个参数都是字符串(不能把正则表达式字面量传递给 RegExp 构造函数) -
可以使用字面量定义的任何表达式,都可以使用构造函数来定义,如:
var pattern1 = /[bc]at/i; //匹配第一个"bat"或"cat",不区分大小写 var pattern2 = new RegExp("[bc]at", "i"); //与 pattern1 相同,只不过是使用构造函数创建的
-
由于RegExp 构造函数的模式参数是字符串,所以在某些情况下要对字符进行双重转义。
所有元字符都必须双重转义,那些已经转义过的字符也是如此。
例如:\n(字符\在字符串中通常被转义为\\,而在正则表达式字符串中就会变成\\\\)
字面量模式 | 等价的字符串 |
---|---|
/ \.at/ | “\\.at” |
/name\ /age/ | “name\\ /age” |
/ \d.\d{1,2}/ | “\\d.\\d{1,2}” |
/ \w\\hello\\123/ | “\\w\\\\hello\\\\123” |
-
RegExp实例方法
-
exec( ):专门为捕获组而设计。exec()接受一个参数,即要应用模式的字符串,然后返回包含第一个匹配项信息的数组;或者在没有匹配项的情况下返回 null
返回的数组虽然是 Array 的实例,但包含两个额外的属性: index 和 input
index:表示匹配项在字符串中的位置
input:表示应用正则表达式的字符串例: var text = "dscat"; var pattern = /.at/; //匹配以"at"结尾的 3 个字符的组合,不区分大小写 var matches = pattern.exec(text); console.log(matches); //["cat", index: 2, input: "dscat", groups: undefined] //返回 包含第一个匹配项信息 的数组 console.log(matches.index); //2:匹配项cat在字符串dscat中的位置 console.log(matches.input) //dscat:应用正则表达式的字符串
-
test( ):接受一个字符串参数。在模式与该参数匹配的情况下返回true;否则,返回 false
只想知道目标字符串与某个模式是否匹配,但不需要知道其文本内容的情况下,使用这个方法非常方便例: var text = "000-00-0000"; var pattern = /\d{3}-\d{2}-\d{4}/; if (pattern.test(text)){ alert("The pattern was matched."); }
-
toLocaleString( ):返回正则表达式的字面量,与创
建正则表达式的方式无关 -
toString( ):返回正则表达式的字面量,与创
建正则表达式的方式无关例: var pattern = new RegExp("\\[bc\\]at", "gi"); alert(pattern.toString()); // /\[bc\]at/gi alert(pattern.toLocaleString()); // /\[bc\]at/gi
-