码迷,mamicode.com
首页 > 其他好文 > 详细

ES6里关于正则表达式的拓展

时间:2017-11-23 08:22:14      阅读:167      评论:0      收藏:0      [点我收藏+]

标签:regex   lag   cti   函数的参数   col   font   改变   情况   第一个   

一、构造函数

  在 ES5 中,RegExp构造函数的参数有两种情况。

  第一种情况是,参数是字符串,这时第二个参数表示正则表达式的修饰符(flag)

var regex = new RegExp(xyz, i);
// 等价于
var regex = /xyz/i;

  第二种情况是,参数是一个正则表示式,这时会返回一个原有正则表达式的拷贝

var regex = new RegExp(/xyz/i);
// 等价于
var regex = /xyz/i;

  但是,ES5 不允许此时使用第二个参数添加修饰符,否则会报错

// Uncaught TypeError: Cannot supply flags when constructing one RegExp from another
var regex = new RegExp(/xyz/, i);

  ES6 改变了这种行为。如果RegExp构造函数第一个参数是一个正则对象,那么可以使用第二个参数指定修饰符。而且,返回的正则表达式会忽略原有的正则表达式的修饰符,只使用新指定的修饰符

console.log(new RegExp(/abc/ig, i).flags);    //i
//上面代码中,原有正则对象的修饰符是ig,它会被第二个参数i覆盖

  flags:ES6 为正则表达式新增了flags属性,会返回正则表达式的修饰符

//ES5的source属性返回正则表达式的正文
/abc/ig.source//"abc"

// ES6的flags属性返回正则表达式的修饰符
/abc/ig.flags//‘gi‘

 

ES6里关于正则表达式的拓展

标签:regex   lag   cti   函数的参数   col   font   改变   情况   第一个   

原文地址:http://www.cnblogs.com/goloving/p/7881624.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!