DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> JavaScript基礎知識 >> JavaScript String.replace函數參數實例說明
JavaScript String.replace函數參數實例說明
編輯:JavaScript基礎知識     
Email:longsu2010 at yeah dot net
js String的replace函數的函數簽名如下:
replace(match/* 字符串OR正則表達式 */, replacement/* 字符串OR函數 */)
作用是將源自符串中的match替換為replacement並返回替換後的字符串。
如果第一參數是字符串就沒什麼好說的了,但是要記住此時只在源自符串替換一次match(第一次)函數就執行完成了。

所以第一參數通常是一個正則表達式,舉例如下:
replace(/a/g, "b") // 將源自符串中所有的a替換為b。

第二參數可以是一個字符串,該字符串中可以包含第一參數正則表達式的分組,舉例如下:
replace(/(a){2,2}/g, "$1b") // 將源自符串中所有的aa替換為ab。

如果第二參數是一個函數的話,那麼函數的參數是什麼呢?舉例如下:
復制代碼 代碼如下:
"bbabc".replace(/(a)(b)/g, function(){
console.log(arguments)
});

參數將依次為:
1、整個正則表達式匹配的字符。
2、第一分組匹配的內容、第二分組匹配的內容…… 以此類推直到最後一個分組。
3、此次匹配在源自符串中的下標(位置)。
4、源自符串
所以例子的輸出是

["ab", "a", "b", 2, "bbabc"]

第二參數的返回值將會被替換到源自符串中,因若js函數無返值那麼調用函數會得到undefined,所以如果第二參數無返回值undefined將會被替換到源自符串中。
如果第一參數是一個字符串,同時第二參數是一個函數的話,那就當成第一參數是一個沒有分組的正則表達式好了,這樣就可以確定第二參數的參數了。
文中有一些表述不當之處,如“替換到源自符串中”(源自符串只是充當模板的角色,並不真正發生改變,字符串是不可改變的變量),希望不會誤導大家。
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved