正则

作者: 卡农me | 来源:发表于2017-10-20 21:57 被阅读14次

    参考
    1.获取指定URL参数

    function getUrlParams(name) { 
        var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i"); //定义正则表达式 
        var r = window.location.search.substr(1).match(reg);  
        if (r != null) return unescape(r[2]); 
      return null; 
    }
    
    window.location = "http://www.baidu.com?name=elephant&age=25&sex=male";
    var name = getUrlParams("name"); //elephant
    var age = getUrlParams("age");   //25
    var sex = getUrlParams("sex"); //male
    
    • (^|&)
      ^匹配字符串开头,&就是&字符
      (^|&)匹配字符串开头或者&字符,如果其后还有正则,那么必须出现在字符串开始或&字符之后
    • =([^&]*)
      ^匹配输入字符串的开始位置,除非在方括号表达式中使用,此时它表示不接受该字符集合。
      上面匹配=后面零个或多个不是&的字符,直至碰到第一个&为止
    • (&|$)
      意思就是匹配以&结尾或者字符一行的末尾位置

    2.获取所有的URL参数

    function parse_url(_url){ //定义函数
      var pattern = /(\w+)=(\w+)/ig;//定义正则表达式
      var parames = {};//定义数组
      url.replace(pattern, function(a, b, c){
        parames[b] = c;
      });
      return parames;//返回这个数组.
    }
    
    var  url = "http://www.baidu.com?name=elephant&age=25&sex=male" 
    var params = parse_url(url);// ["name=elephant", "age=25", "sex=male"]
    

    3.正则表达式中/i,/g,/ig,/gi,/m的区别和含义
    /i (忽略大小写)
    /g (全文查找出现的所有匹配字符)
    /m (多行查找)
    /gi(全文查找、忽略大小写)
    /ig(全文查找、忽略大小写)

    4.match
    这个方法的行为在很大程度上有赖于 regexp 是否具有标志 g。
    如果 regexp 没有标志 g,那么 match() 方法就只能在 stringObject 中执行一次匹配。如果没有找到任何匹配的文本, match() 将返回 null。否则,它将返回一个数组,其中存放了与它找到的匹配文本有关的信息。

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

    5.正则表达式中?=和?:和?!的理解

    要理解?=和?!,首先需要理解前瞻,后顾,负前瞻,负后顾四个概念:
    
    前瞻:
    exp1(?=exp2) 查找exp2前面的exp1
    后顾:
    (?<=exp2)exp1 查找exp2后面的exp1
    负前瞻:
    exp1(?!exp2) 查找后面不是exp2的exp1
    负后顾:
    (?<!=exp2)exp1 查找前面不是exp2的exp1
    

    举例:

    "中国人".replace(/(?<=中国)人/, "rr") // 匹配中国人中的人,将其替换为rr,结果为 中国rr
    "法国人".replace(/(?<=中国)人/, "rr") // 结果为 法国人,因为人前面不是中国,所以无法匹配到
    

    相关文章

      网友评论

          本文标题:正则

          本文链接:https://www.haomeiwen.com/subject/yhlbuxtx.html