javascript中replace()字元替換詳解

來源:互聯網
上載者:User

replace() 方法用於在字串中用一些字元替換另一些字元,或替換一個與Regex匹配的子串。

文法
stringObject.replace(regexp/substr,replacement)

傳回值
一個新的字串,是用 replacement 替換了 regexp 的第一次匹配或所有匹配之後得到的。

說明
字串 stringObject 的 replace() 方法執行的是尋找並替換的操作。它將在 stringObject 中尋找與 regexp 相匹配的子字串,然後用 replacement 來替換這些子串。如果 regexp 具有全域標誌 g,那麼 replace() 方法將替換所有匹配的子串。否則,它只替換第一個匹配子串。

執行個體

 代碼如下 複製代碼

<script language="javascript">
var strM = "javascript is a good script language";
//在此我想將字母a替換成字母A
alert(strM.replace("a","A"));
</script>

它只替換了首字母。但如果加上Regex結果就不一樣了!replace()支援Regex,它可以按照Regex的規則匹配字元或字串,然後給予替換!

 代碼如下 複製代碼

<script language="javascript">
var strM = "javascript is a good script language";
//在此我想將字母a替換成字母A
alert(strM.replace(/a/,"A"));
</script>

這樣還是只替換了第一個字母a。

 代碼如下 複製代碼
<script language="javascript">
var strM = "javascript is a good script language";
//在此將字母a全部替換成字母A
alert(strM.replace(/a/g,"A"));
</script>

由上可知,當Regex有"g"標誌時,代表將處理整個字串.

 

 代碼如下 複製代碼
<script language="javascript">
var strM = "javascript is a good script language";
alert(strM.replace(/(javascript)s*(is)/g,"$1 $2 fun. it $2"));
</script>

例2

 代碼如下 複製代碼

<script language="javascript"> 
var reg=new RegExp("終古","g"); //建立正則RegExp對象 
var stringObj="終古人民共和國,終古人民"; 
var newstr=stringObj.replace(reg,"中國");  
alert(newstr); 
</script>


先看看簡單例子:將所有單詞首字母換成大寫。

 代碼如下 複製代碼

<script language="javascript">
var strM = "javascript is a good script language";
function change(word)
{
return word.indexOf(0).toUpperCase()+word.substring(1);
}
alert(strM.replace(/bw+b/g,change));
</script>

由上可知,當Regex有"g"標誌時,代表將處理整個字串,即函數change的變換將應用於所有匹配的對象。而該函數有三個或更多參數,具體個數視Regex而定。

有了函數與Regex的配合,replace()處理字串的功能空前強大起來了!

最後還舉個例子,將字串所有單詞倒序,用replace()處理是如此簡單。

 代碼如下 複製代碼
<script language="javascript">
var strM = "javascript is a good script language";
function change(word)
{
var result = word.match(/(w)/g);
if ( result )
{
var str = "";
for ( var i=result.length-1; i>=0; i-- )
{
str += result;
}
return str;
}
else
{
return "null";
}
}
alert(strM.replace(/b(w)+b/g,change));
</script>

注意:ECMAScript v3 規定,replace() 方法的參數 replacement 可以是函數而不是字串。在這種情況下,每個匹配都調用該函數,它返回的字串將作為替換文本使用。該函數的第一個參數是匹配模式的字串。接下來的參數是與模式中的子運算式匹配的字串,可以有 0 個或多個這樣的參數。接下來的參數是一個整數,聲明了匹配在 stringObject 中出現的位置。最後一個參數是 stringObject 本身。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.