欢迎光临,了解微信小程序开发,就上易用通!

扩展微信小程序框架功能:正则表达式

发布:2018-04-14 14:40浏览: 来源:网络 作者:cola

XRegExp 是一个开源的 JavaScript 库提供一个参数化、可扩展的支持各种浏览器的正则表达式的实现库,支持附加语法、标志以及方法。

XRegExp

XRegExp是一个为JS的正则表达式提供扩展功能的库, 调用之后可以弥补原生JS在正则方面的一些不足,也在很大程度上增强了JS正则的功能。它解决了浏览器之间正则的兼容问题,且支持原生ES6正则语法。

XRegExp的主要特性:

  • 扩展的正则语法,包括支持命名的捕获组以及更强大的文本替换
  • 增加修饰符(flags)s支持单行模式;x 忽略空格以及行注释;n 明确捕获组模式;A 支持21位Unicode匹配
  • 提供一套函数简化正则处理
  • 解决跨浏览器的正则兼容问题
  • 在此基础上提供扩展(addons)支持更多的正则语法和功能

XRegExp 使用

XRegExp 的最主要的 API 是构造函数,语法如下:

    XRegExp(pattern, [flags])
  • pattern参数为字符型的正则表达式
  • [flags]为可选的正则修饰符,当然也是字符型,它支持原生的修饰符以及XRegExp中的扩展修饰符

    返回值为被扩展的正则对象。

    var date = XRegExp('(?<year>  [0-9]{4} ) -?  # year  \n\
                (?<month> [0-9]{2} ) -?  # month \n\
                (?<day>   [0-9]{2} )     # day   ', 'x');    var match = XRegExp.exec('2015-02-22', date);    console.log(match.year); // 输出:2015

forEach

    var evens = [];
    XRegExp.forEach('1a2345', /\d/, function (match, i) {        if (i % 2) evens.push(+match[0]);
    });    console.log(evens); // 输出:[2, 4]

matchChain

    var result1 = XRegExp.matchChain('1 <b>2</b> 3 <b>4 a 56</b>', [
        XRegExp('(?is)<b>.*?</b>'),        /\d+/
    ]);    console.log(result1); // 输出:["2", "4", "56"]
    var html = '<a href="https://xregexp.com/">XRegExp</a>' +        '<a href="https://www.google.com/">Google</a>';    var result2 = XRegExp.matchChain(html, [
        { regex: /<a href="([^"]+)">/i, backref: 1 },
        { regex: XRegExp('(?i)^https?://(?<domain>[^/?#]+)'), backref: 'domain' }
    ]);    console.log(result2); // 输出:["xregexp.com", "www.google.com"]

union

    var result3 = XRegExp.union(['a+b*c', /(dog)\1/, /(cat)\1/], 'i');    console.log(result3); // 输出:/a\+b\*c|(dog)\1|(cat)\2/i

exec

    var pos = 3;    var result4 = [];    while (match = XRegExp.exec('<1><2><3><4>5<6>', /<(\d+)>/, pos, 'sticky')) {
        result4.push(match[1]);
        pos = match.index + match[0].length;
    }    console.log(result4);  // 输出:['2', '3', '4']

replace

    var result5 = XRegExp.replace('2015-02-22', date, '${month}/${day}/${year}');    console.log(result5);
    var result6 = XRegExp.replace('2015-02-22', date, function (match) {        return match.month + '/' + match.day + '/' + match.year;
    });    console.log(result6);

参考资料

  • XRegExp
  • XRegExp@github
  • JavaScript正则库:XRegExp

其他


 
 
 




免责声明:本站所有文章和图片均来自用户分享和网络收集,文章和图片版权归原作者及原出处所有,仅供学习与参考,请勿用于商业用途,如果损害了您的权利,请联系网站客服处理。