美文网首页
RegExp查找替换

RegExp查找替换

作者: overflow_hidden | 来源:发表于2017-03-31 22:40 被阅读43次

    RegExp 对象有 3 个方法:test()、exec() 以及 compile()。

    1.test()

    test() 方法检索字符串中的指定值。返回值是 true 或 false。

    var patt1=new RegExp("e");
    
    document.write(patt1.test("The best things in life are free")); // true
    
    2.exec()

    exec() 方法检索字符串中的指定值,返回找到的值,并确定其位置。
    该函数返回一个数组,其中存放匹配的结果。如果未找到匹配,则返回值为 null。

    var patt1=new RegExp("e");
    document.write(patt1.test("The best things in life are free")); // e
    
    3.compile()

    函数用于更改正则表达式模式,并将正则表达式模式编译为内部格式,从而执行得更快。

    var str = "abc12456def45646ghi";
    var regExp = new RegExp("[a-z]+");
    document.writeln( regExp.exec(str) ); // abc
    // 更改regExp的正则表达式模式,并进行编译
    // 这与下列语句的作用是相同的:regExp = /\d+/;
    regExp.compile("\\d+");
    document.writeln( regExp.exec(str) ); // 12456
    
    4.global

    您可以向 RegExp 对象添加第二个参数,以设定检索。例如,如果需要找到所有某个字符的所有存在,则可以使用 "g" 参数 ("global")。

    var patt1=new RegExp("e","g");
    do
    {
       result=patt1.exec("The best things in life are free");
       document.write(result);
    }  
    while (result!=null)
    //由于这个字符串中 6 个 "e" 字母,代码的输出将是:eeeeeenull
    

    eg: 将content中所有的 0是不固定的,替换成images数组中对应图片。

    var content = res.content;   
    var images = res.imgs;        
    var reg_img =  /<!--IMG#\d{1,9}-->/g ;
    var result;   
    var num = 0; 
     while ((result = reg_img.exec(content)) != null)  {   
          // console.log(reg_img.lastIndex);  
         // console.log(result[0]);   
          content = content.replace(new RegExp(result[0]), "<im
          g src='"+images[num].src+"'/>");
          num++; 
    }
    
    5.相关知识:支持正则表达式的 String 对象的方法
    • search: 检索与正则表达式相匹配的值。
      var str="Visit W3School!"
      document.write(str.search(/W3School/))
      //6 返回第一次匹配到的位置

    • match: 找到一个或多个正则表达式的匹配。

      var str="1 plus 2 equal 3"
      console.log(str.match(/\d+/g));
      //[1,2,3];
      
    match返回值
    • replace: 替换与正则表达式匹配的子串。
      stringObject.replace(regexp/substr,replacement)
      • regexp/substr: 必需。规定子字符串或要替换的模式的 RegExp 对象。请注意,如果该值是一个字符串,则将它作为要检索的直接量文本模式,而不是首先被转换为 RegExp 对象
      • replacement:必需。一个字符串值。规定了替换文本或生成替换文本的函数。
      var str="Visit Microsoft!"
      console.log(str.replace(/Microsoft/, "W3School"))
      // Visit W3School!
      //(/Microsoft/g  全局替换  
      //(/Microsoft/i 不区分大小写替换
    
     //在本例中,我们将把字符串中所有单词的首字母都转换为大写:
    var name = 'aaa bbb ccc';
     uw=name.replace(/\b\w+\b/g, function(word){
       return word.substring(0,1).toUpperCase()+word.substring(1);
     });
    // "Aaa Bbb Ccc"
    
    • split: 把字符串分割为字符串数组,很常用。
    
    js截取两个字符串之间的内容:  
      
    var str = "aaabbbcccdddeeefff";  
    str = str.match(/aaa(\S*)fff/)[1];  
    alert(str);//结果bbbcccdddeee  
    
    var str = "aaab<h2>bbcccddde</h2>eefff";  
    str = str.match(/<h2>(\S*)<\/h2>/)[1];  //bbcccddde
    

    相关文章

      网友评论

          本文标题:RegExp查找替换

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