js 實現ReplaceAll 的方法

JS  字符串有replace() 方法。但這個方法只會對匹配到的第一個字串替換。 以下例:this

<HTML>
<HEAD>
<TITLE> New Document </TITLE>
</HEAD>

<BODY>
<script>
   var str = "wordwordwordword";
   var strNew = str.replace("word","Excel");
   alert(strNew);
</script>
</BODY>
</HTML>

若是要所有替換的話,JS 沒有提供replaceAll這樣的方法。使用正則表能夠達成Replace 的效果:spa

str.replace(/word/g,"Excel")

g 的意義是:執行全局匹配(查找全部匹配而非在找到第一個匹配後中止)。prototype

<HEAD>
<TITLE> New Document </TITLE>
<script>
function replaceAll(str)
{
    if(str!=null)
    str = str.replace(/word/g,"Excel")
    return str;
}
</script>
</HEAD>

<BODY>
<script>
   var str = "wordwordwordword";
   var strNew = str.replace("word","Excel");
   strNew = replaceAll(str);
   alert(strNew);
</script>
</BODY>
</HTML>

以上寫法有個類同的寫法:code

str.replace(new RegExp("word","gm"),"Excel")

g 執行全局匹配(查找全部匹配而非在找到第一個匹配後中止)。對象

m 執行多行匹配。blog

除此以外,也能夠添加 Stirng對象的原型方法:ip

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

這樣就能夠像使用replace 方法同樣使用replaceAll了字符串

str.replaceAll("word","Excel");

總結一下, 三種方式原型

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

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

3. 增長String 對象原型方法 replaceAll

相關文章
相關標籤/搜索