js replace如何?replaceAll

來源:互聯網
上載者:User

標籤:sub   而不是   對象   blog   www   ons   bst   調用   模式   

js下string對象的replace方法的定義如下:

stringObject.replace(regexp/substr,replacement)

其中:

      參數             |              描述

regexp/substr     | 必需。規定子字串或要替換的模式的 RegExp 對象。

replacement       | 必需。一個字串值。規定了替換文本或產生替換文本的函數。

傳回值

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

說明

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

replacement 可以是字串,也可以是函數。如果它是字串,那麼每個匹配都將由字串替換。但是 replacement 中的 $ 字元具有特定的含義。如下表所示,它說明從模式比對得到的字串將用於替換。

 字元                       | 替換文本

$1、$2、...、$99  | 與 regexp 中的第 1 到第 99 個子運算式相匹配的文本。

$&                          | 與regexp相匹配的子串。

$`(在Tab鍵上面那個)  | 位於匹配子串左側的文本。

$‘                           | 位於匹配子串右側的文本。

$$          | 直接量符號。

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

上面是w3school上面對string對象replace方法的說明。下面來看測試:

var str = ‘BbBb‘;console.log(str.replace(‘B‘,‘b‘));

此時控制台會列印:‘bbBb‘,而不是‘bbbb‘。

也就是說,當參數‘regexp/substr‘是一個字串時,只會替換掉第一個匹配的子字串。而js的string對象又沒提供replaceAll方法,所以只能嘗試另一種方法,參數‘regexp/substr‘是一個Regex對象--RegExp對象。

先來看看什麼是RegExp對象(已經理解的直接跳過),下面是RegExp對象的建立方式:

直接量文法:

/pattern/attributes

建立RegExp對象的文法:

new RegExp(pattern, attributes);
參數

參數 pattern 是一個字串,指定了Regex的模式或其他Regex。

參數 attributes 是一個可選的字串,包含屬性 "g"、"i" 和 "m",分別用於指定全域匹配、區分大小寫匹配和多行匹配。ECMAScript 標準化之前,不支援 m 屬性。如果 pattern 是Regex,而不是字串,則必須省略該參數。

傳回值

一個新的 RegExp 對象,具有指定的模式和標誌。如果參數 pattern 是Regex而不是字串,那麼 RegExp() 建構函式將用與指定的 RegExp 相同的模式和標誌建立一個新的 RegExp 對象。

如果不用 new 運算子,而將 RegExp() 作為函數調用,那麼它的行為與用 new 運算子調用時一樣,只是當 pattern 是Regex時,它只返回 pattern,而不再建立一個新的 RegExp 對象。

拋出

SyntaxError - 如果 pattern 不是合法的Regex,或 attributes 含有 "g"、"i" 和 "m" 之外的字元,拋出該異常。

TypeError - 如果 pattern 是 RegExp 對象,但沒有省略 attributes 參數,拋出該異常。

用RegExp對象測試上面的例子:

var str = ‘BbBb‘;console.log(str.replace(new RegExp(‘B‘),‘b‘));

此時列印的結果是:‘bbBb‘,還是只替換第一個匹配的子字串。再來看看RegExp建構函式對象第二參數的說明:

修飾符      | 描述

i            | 執行對大小寫不敏感的匹配。

g             | 執行全域匹配(尋找所有匹配而非在找到第一個匹配後停止)。

m            | 執行多行匹配。

從上面可以看到,當第二個參數字串包含‘g‘這一字元,則會進行全域匹配。下面來測試一下:

var str = ‘BbBb‘;console.log(str.replace(new RegExp(‘B‘,‘g‘),‘b‘)); 

此時列印了:‘bbbb‘。這才是我們想要的結果。

當然上面建立RegExp對象也可以用直接量方式。

new RegExp(‘B‘)  == /B/new RegExp(‘B‘,‘g‘) == /B/g

順便來看一下大小寫不敏感的匹配,與全域匹配一起使用:

var str = ‘BbBb‘;console.log(str.replace(/b/gi,‘a‘));

此時會列印:‘aaaa‘。

其實關鍵是在與Regex的使用。附上w3school上面RegExp對象的介紹:http://www.w3school.com.cn/jsref/jsref_obj_regexp.asp

js replace如何?replaceAll

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.