js使用正则实现ReplaceAll全部替换

 

JS 没有提供replaceAll这样的方法,JS 字符串有replace() 方法。但这个方法只会对匹配到的第一个字串替换。如下例:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  <script>
    var str = "abcdefabcdefabcdef";
    var newStr = str.replace("abc","123");
    alert(newStr);
  </script>
</body>
</html>

 

如果要全部替换的话,JS 没有提供replaceAll这样的方法。使用正则表可以达成Replace 的效果:

str.replace(/abc/g,"123")

g 的意义是:执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  <script>
    function replaceAll(str){
    if(str != null)
      str = str.replace(/abc/g,"123")
      return str;
    }
    var str = "abcdefabcdefabcdef";
    //var newStr = str.replace("abc","123");
    var newStr = replaceAll(str);
    alert(newStr);
  </script>
</body>
</html>

以上写法有个类同的写法:

str.replace(new RegExp("abc","gm"),"123")

g 执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)。

m 执行多行匹配。

除此之外,也可以添加 Stirng对象的原型方法:

String.prototype.replaceAll = function(s1,s2){ 
    return this.replace(new RegExp(s1,"gm"),s2); 
}

这样就可以像使用replace 方法一样使用replaceAll了。

str.replaceAll("abc","123");

 

 

1. str.replace(/oldString/g,newString);

2. str.replace(new RegExp(oldString,"gm"),newString);

3. 增加String 对象原型方法 replaceAll;

posted @ 2021-03-26 10:11  馬先森  阅读(1888)  评论(0编辑  收藏  举报