首页 > 技术文章 > javascript 正则表达式

MrTao 2016-12-28 10:45 原文

RegExp 是正则表达式的缩写。 (英语:Regular Expression,在代码中常简写为regex、regexp或RE)

当您检索某个文本时,可以使用一种模式来描述要检索的内容。RegExp 就是这种模式。

简单的模式可以是一个单独的字符。

更复杂的模式包括了更多的字符,并可用于解析、格式检查、替换等等。

您可以规定字符串中的检索位置,以及要检索的字符类型,等等。

速记理解技巧编辑

.[ ]^$

四个字符是所有语言都支持的正则表达式,所以这个四个是基础的正则表达式。正则难理解因为里面有一个等价的概念,这个概念大大增加了理解难度,让很多初学者看起来会懵,如果把等价都恢复成原始写法,自己书写正则就超级简单了,就像说话一样去写你的正则了:

等价:等价是等同于的意思,表示同样的功能,用不同符号来书写。

  ?,*,+,\d,\w 都是等价字符

?等价于匹配长度{0,1}
*等价于匹配长度{0,} 
+等价于匹配长度{1,}
\d等价于[0-9]
\D等价于[^0-9]
\w等价于[A-Za-z_0-9]
\W等价于[^A-Za-z_0-9]。 

语法与释义:

基础语法 "^([]{})([]{})([]{})$"
正则字符串 = "开始([包含内容]{长度})([包含内容]{长度})([包含内容]{长度})结束" 

使用

// new RegExp(pattern, attributes);
var patt1=new RegExp(regexp);
当您使用该 RegExp 对象在一个字符串中检索时,将寻找的是字符 regexp。

参数 pattern 是一个字符串,指定了正则表达式的模式或其他正则表达式。

参数 attributes 是一个可选的字符串,包含属性 "g"、"i" 和 "m",分别用于指定全局匹配、区分大小写的匹配和多行匹配。ECMAScript 标准化之前,不支持 m 属性。如果 pattern 是正则表达式,而不是字符串,则必须省略该参数。 

RegExp 对象的方法

RegExp 对象有 3 个方法:test()、exec() 以及 compile()。

test()

例子:

var patt1=new RegExp("e");
document.write(patt1.test("The best things in life are free")); 

由于该字符串中存在字母 "e",以上代码的输出将是:true

exec()

exec() 方法检索字符串中的指定值。返回值是被找到的值。如果没有发现匹配,则返回 null。

例子

var patt1=new RegExp("e");
document.write(patt1.exec("The best things in life are free")); 

由于该字符串中存在字母 "e",以上代码的输出将是:e

例子 2:

您可以向 RegExp 对象添加第二个参数,以设定检索。例如,如果需要找到所有某个字符的所有存在,则可以使用 "g" 参数 ("global")。

如需关于如何修改搜索模式的完整信息,请访问我们的 RegExp 对象参考手册。

在使用 "g" 参数时,exec() 的工作原理如下:

  • 找到第一个 "e",并存储其位置
  • 如果再次运行 exec(),则从存储的位置开始检索,并找到下一个 "e",并存储其位置
var patt1=new RegExp("e","g");
do
{
result=patt1.exec("The best things in life are free");
document.write(result);
}
while (result!=null) 

由于这个字符串中 6 个 "e" 字母,代码的输出将是:eeeeeenull

compile()

compile() 方法用于改变 RegExp。

compile() 既可以改变检索模式,也可以添加或删除第二个参数。

例子:

var patt1=new RegExp("e");
document.write(patt1.test("The best things in life are free"));
patt1.compile("d");
document.write(patt1.test("The best things in life are free"));

由于字符串中存在 "e",而没有 "d",以上代码的输出是:true、false

写正确的正则表达式还需要了解

修饰符

i: 修饰符用于执行对大小写不敏感的匹配。

var str="Visit W3School";
var patt1=/w3school/i;
var reg = new RegExp(patt1)
var result = reg.test(str)

g: 修饰符用于执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)。

var str="Is this all there is?";
var patt1=/is/gi;
document.write(str.match(patt1)); // Is,is,is

 

 

 

 

  

search() 方法用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符串。

var str="Visit W3School!"
document.write(str.search(/w3school/i))

match() 方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。

该方法类似 indexOf() 和 lastIndexOf(),但是它返回指定的值,而不是字符串的位置。

var str="1 plus 2 equal 3"
document.write(str.match(/\d+/g))

replace() 方法用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。

text = "javascript Tutorial";
text.replace(/javascript/i, "JavaScript");

split() 方法用于把一个字符串分割成字符串数组。

var str="Is this all there is?"
var words = str.split(/\s+/) // Is,this,all,there,is?

 

 

 

推荐阅读