zoukankan      html  css  js  c++  java
  • javascript的正则表达式学习

    关于反向引用

    复制代码 代码如下:


    // 测试函数
    function matchReg(reg, str) {
    var result = str.match(reg);
    if(result) {
    console.dir(result);
    } else {
    console.log('match failed');
    }
    }

    var reg = /([A-Za-z]{0,6})1/;
    var str = 'AndrewAndrew';
    // 测试通过
    matchReg(reg, str);

    //通过(?:pattern)的方式,不记录子表达式匹配的内容(本例中为Andrew)
    //所以1对子表达式匹配内容的引用失败了
    //注意:这里强调的是子表达式所匹配的内容,而不是子表达式本身
    reg = /(?:[a-zA-Z]{0,6})1/;
    // 测试不通过
    matchReg(reg, str);


    关于子表达式的定义
    var parse_number = /^-?d+(?:.d*)?(?:e[+-]?d+)?$/i;
    这是一个解析数字的正则表达式,其中的子表达式有(?:.d*)和(?:e[+-]?d+)
    .和-分别是对.和-的转义表达
    顺便复习下.表示除换行符以外的其他字符
    -一般用于[a-zA-Z0-9]表示匹配范围
    如果其中没?:例如(.d*)那么按照先后顺序,反向引用的关系如下
    1-->(.d*)
    2-->(e[+-]?d+)
    如果有更多的话,就以此类推3 4 5....
    再次强调,引用的是子表达式匹配的内容,是具体的文本
    关于正向预查

    复制代码 代码如下:


    var reg = /I like (?=shanghai)/;
    var str = 'I like shanghai';
    matchReg(reg, str); //测试通过

    str = 'I like beijing';
    matchReg(reg, str); //不通过


    跑下上面的代码,就马上理解什么算是正向预查了,如上面的例子,通过(?=pattern)的形式,正则 表达式预测下后面的内容是不是符合要求,如果是那就顺利匹配.
    相对地,(?!=pattern)的使用意图正好与(?=pattern)相反,就不复述了
    关于贪心和非贪心匹配模式

    复制代码 代码如下:


    // 贪心
    var reg = /d{1,}/;
    var str = '1999';
    matchReg(reg, str); // result[0]为1999 能多匹配就多匹配

    // 非贪心
    reg = /d{1,}?/;
    matchReg(reg, str); // result[0]为1 只匹配了一个


    从上面的结果很容易看出"贪心"和"非贪心"的含义
    pattern?这就表明非贪心匹配模式,一般情况就是贪心的
    关于Regexp对象exec函数返回的结果

    复制代码 代码如下:


    // 关于返回结果是个什么
    // matchReg函数中console.dir(result)能说明问题,firebug中一看便知
    关于string的replace函数
    function camelize(str) {
    return str.replace(/-(w)/g, function(inputStr, p1) {
    console.log(p1);
    return p1.toUpperCase();
    });
    }
    console.log(camelize('background-color'));

    function uncamelize(str, sep) {
    sep = sep || '-';
    return str.replace(/([a-z])([A-Z])/g, function(inputStr, p1, p2) {
    console.log('p1:%s, p2:%s', p1, p2);
    return p1 + sep + p2;
    });
    }
    console.log(uncamelize('backgroundColor', '-'));


    上面两个例子,主要用于说明replace函数的用法,当然还有search,split等函数可以充分利用正则表达式的优势
    关于javascript正则表达式的最佳实践
    就一句话:尽量的精简,不要复杂,利于读懂和维护!

  • 相关阅读:
    Linux perf命令详解及常用参数解析
    pidstat 命令(Linux 进程使用资源情况采样)
    Katalon Studio入门学习之三种获取元素方式
    用Spring和c3p0工具简单的实现增删改查
    Spring AOP(面向切面示例)
    Spring属性注入、构造方法注入、工厂注入以及注入参数(转)
    PowerDesigner最基础的使用方法入门学习(转)
    Struts文件上传
    struts转换器
    Struts拦截器
  • 原文地址:https://www.cnblogs.com/wangqiniqn/p/6204619.html
Copyright © 2011-2022 走看看