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。如果您熟悉正則,那這就難不住您。稍加修改就OK了。
<script language="javascript">
var strM = "javascript is a good script language";
//在此將字母a全部替換成字母A
alert(strM.replace(/a/g,"A"));
</script>
還可以這樣,看看效果!
<script language="javascript">
var strM = "javascript is a good script language";
alert(strM.replace(/(javascript)\s*(is)/g,"$1 $2 fun. it $2"));
</script>
我這兒舉的例子都是很簡單的應用,replace()在此點上與您使用Regex的能力成正比。您Regex越強,呵呵,那您就會越瘋狂的愛上它。
當然,我這兒推薦replace()的原因並不因為它能與Regex合作,而在於它還能與函數進行合作,發揮出強大的功能。
先看看簡單例子:將所有單詞首字母換成大寫。
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]
由上可知,當Regex有"g"標誌時,代表將處理整個字串,即函數change的變換將應用於所有匹配的對象。而該函數有三個或更多參數,具體個數視Regex而定。
有了函數與Regex的配合,replace()處理字串的功能空前強大起來了!
最後還舉個例子,將字串所有單詞倒序,用replace()處理是如此簡單。
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]