JavaScript RegExp 对象

来源:互联网 发布:儿童读书软件 编辑:程序博客网 时间:2024/06/10 08:51

RegExp 对象

正则表达式是描述字符模式的对象。
正则表达式用于对字符串模式匹配及检索替换,是对字符串执行模式匹配的强大工具。

注意:当使用构造函数创造正则对象时,需要常规的字符转义规则(在前面加反斜杠 \)。比如,以下是等价的:

var re = new RegExp("\\w+");var re = /\w+/;

修饰符

修饰符用于执行区分大小写和全局匹配:

修饰符 描述 i 执行对大小写不敏感的匹配。 g 执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)。 m 执行多行匹配。
<script text="text/javascript">  var txt = 'Hello World!'  var reg = new RegExp('hello', 'i');  if(reg.test(txt)) {    console.log(txt.match(reg));//["Hello", index: 0, input: "Hello World!"]  }</script>
<script text="text/javascript">  var txt = 'This is just a test.'  var reg = new RegExp('is', 'g');//区分大小写  var reg01 = new RegExp('is', 'gi');//不区分大小写  if(reg.test(txt)) {    console.log(txt.match(reg));//["is", "is"]    console.log(txt.match(reg).length);//2  }</script>
<script type="text/javascript">  //以下代码不能够匹配字符串"an",尽管"an"后面已经换行了,但"an"并不是字符串行的结尾。  var txt1 = 'This is an\n apple';   var reg1 = /an$/;  console.log(txt1.match(reg1));//null  //以下代码能够匹配到字符串"an"  var txt2 = 'This is an\n apple';  var reg2 = /an$/m;  console.log(txt2.match(reg2));//["an", index: 8, input: "This is an↵ apple"]    //以下是多行匹配开头示例  var txt3 = 'This is an\n apple';  var reg3 = /^\sapp/;  console.log(txt3.match(reg3));//null  var txt4 = 'This is an\n apple';  var reg4 = /^\sapp/m;// /^ app/m  console.log(txt4.match(reg4));//[" app", index: 11, input: "This is an↵ apple"]

方括号

方括号用于查找某个范围内的字符:

表达式 描述 [abc] 查找方括号之间的任何字符。 [^abc] 查找任何不在方括号之间的字符。 [0-9] 查找任何从 0 至 9 的数字。 [a-z] 查找任何从小写 a 到小写 z 的字符。 [A-Z] 查找任何从大写 A 到大写 Z 的字符。 [A-z] 查找任何从大写 A 到小写 z 的字符。 [adgk] 查找给定集合内的任何字符。 [^adgk] 查找给定集合外的任何字符。 (red blue green) 查找任何指定的选项。

元字符

元字符(Metacharacter)是拥有特殊含义的字符:

元字符 描述 . 查找单个字符,除了换行和行结束符。 \w 查找单词字符。 \W 查找非单词字符。 \d 查找数字。 \D 查找非数字字符。 \s 查找空白字符。 \S 查找非空白字符。 \b 匹配单词边界。 \B 匹配非单词边界。 \0 查找 NULL 字符。 \n 查找换行符。 \f 查找换页符。 \r 查找回车符。 \t 查找制表符。 \v 查找垂直制表符。 \xxx 查找以八进制数 xxx 规定的字符。 \xdd 查找以十六进制数 dd 规定的字符。 \uxxxx 查找以十六进制数 xxxx 规定的 Unicode 字符。

量词

量词 描述 n+ 匹配任何包含至少一个 n 的字符串。 n* 匹配任何包含零个或多个 n 的字符串。 n? 匹配任何包含零个或一个 n 的字符串。 n{X} 匹配包含 X 个 n 的序列的字符串。 n{X,Y} 匹配包含 X 或 Y 个 n 的序列的字符串。 n{X,} 匹配包含至少 X 个 n 的序列的字符串。 n$ 匹配任何结尾为 n 的字符串。 ^n 匹配任何开头为 n 的字符串。 ?=n 匹配任何其后紧接指定字符串 n 的字符串。 ?!n 匹配任何其后没有紧接指定字符串 n 的字符串。

RegExp对象属性

1.global
  返回正则表达式是否具有”g”修饰符;

<script type="text/javascript">  var txt = 'This is just a test';  var reg = new RegExp('st', 'g');  if(reg.global) {    console.log(txt.match(reg));//["st", "st"]  }</script>

2.ignoreCase
  返回正则表达式是否具有”i”修饰符;
  
3.multiline
  返回正则表达式是否具有”m”修饰符;
  
4.lastIndex
  标记下一次匹配开始时所在字符串的位置;

<script type="text/javascript">  var txt = 'If you love code, you should code everyday.';  var reg = new RegExp('ou', 'g');  var length = txt.match(reg).length;  for(var i = 0; i < length; i++) {    reg.test(txt);    console.log(reg.lastIndex);  }</script>

5.source
  返回正则表达式进行模式匹配的文本或表达式,返回的文本中不包括修饰符”i”,”g”,”m”,也不包括正则表达式直接量使用的定界符

<script>  var reg1 = new RegExp('yoho', 'm');  var reg2 = new RegExp('\\w');  var reg3 = /\w/m;  console.log(reg1.source);//yoho  console.log(reg2.source);//\w  console.log(reg3.source);//\w</script>

RegExp对象方法

1.compile

  改变或重新编译正则表达式(Opera浏览器不支持该方法)
  对于正则表达式的重新定义,以下方法就可以实现。

<script>  var reg = new RegExp('ou', 'g');  reg = /\w/;</script>

2.exec
  检索字符串中正则表达式的匹配结果

<script>  var txt = 'If you love code, you should code everyday.';  var reg = new RegExp('ou', 'g');  var length = txt.match(reg).length;  for(var i = 0; i < length; i++) {    console.log(reg.exec(txt));  }</script>

3.test
  检测字符串是否与匹配正则表达式匹配

<script>  var txt = 'I code everyday.';  var reg = new RegExp('code');  console.log(reg.test(txt));//true</script>
原创粉丝点击