JavaScript RegExp Regex對象詳細說明

來源:互聯網
上載者:User
文章目錄
  • 傳回值
  • 說明
  • 傳回值
  • 說明
  • 傳回值
  • 說明
  • 文法
  • 傳回值

直接量文法

/pattern/attributes

建立 RegExp 對象的文法: 複製代碼 代碼如下:var obj=new RegExp(pattern,attributes);

案例1:
複製代碼 代碼如下:var pattern=/a/;
document.write(pattern.exec("asdas"));

案例2: 複製代碼 代碼如下:var obj=new RegExp("a");
document.write(obj.exec("asdas"));

案例1和案例2的執行結果是相同的;
參數
參數 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 對象方法:
1、test():檢索字串中指定的值。返回 true 或 false。 複製代碼 代碼如下:var patt1=new RegExp("e");
document.write(patt1.test("The best things in life are free"));

2、exec():檢索字串中指定的值。返回找到的值,並確定其位置。 複製代碼 代碼如下:方法檢索字串中的指定值。傳回值是被找到的值。如果沒有發現匹配,則返回 null。

3、compile():既可以改變檢索模式,也可以添加或刪除第二個參數。 複製代碼 代碼如下:var patt1=new RegExp("e");
document.write(patt1.test("The best things in life are free"));
patt1.compile("d");
document.write(patt1.test("The best things in life are free"));

修飾符:

1、g:執行全域匹配尋找所有匹配而非在找到第一個匹配後停止;
在使用 "g" 參數時,exec() 的工作原理如下:
找到第一個 "e",並儲存其位置
如果再次運行 exec(),則從儲存的位置開始檢索,並找到下一個 "e",並儲存其位置 複製代碼 代碼如下:var patt1=new RegExp("e","g");
do
{
result=patt1.exec("The best things in life are free");
document.write(result);
}
while (result!=null)

RegExp 對象屬性
1:global:RegExp 對象是否具有標誌 g。
2:ignoreCase:RegExp 對象是否具有標誌 i。
3:lastIndex:一個整數,標示開始下一次匹配的字元起始位置。
4:multiline:RegExp 對象是否具有標誌 m;
5:source:Regex的源文本。

複製代碼 代碼如下:var obj=new RegExp(/s/);
document.write(obj.source);

支援Regex的 String 對象的方法
1:search() 方法用於檢索字串中指定的子字串,或檢索與Regex相匹配的子字串。
忽略大小寫案例: 複製代碼 代碼如下:<script type="text/javascript">
var str="Visit W3School!"
document.write(str.search(/w3school/i))
</script>

傳回值

stringObject 中第一個與 regexp 相匹配的子串的起始位置。

注釋:如果沒有找到任何匹配的子串,則返回 -1。

說明

search() 方法不執行全域匹配,它將忽略標誌 g。它同時忽略 regexp 的 lastIndex 屬性,並且總是從字串的開始進行檢索,這意味著它總是返回 stringObject 的第一個匹配的位置。

2:match() 方法可在字串內檢索指定的值,或找到一個或多個Regex的匹配。該方法類似 indexOf() 和 lastIndexOf(),但是它返回指定的值,而不是字串的位置。

傳回值

存放匹配結果的數組。該數組的內容依賴於 regexp 是否具有全域標誌 g。

說明

match() 方法將檢索字串 stringObject,以找到一個或多個與 regexp 匹配的文本。這個方法的行為在很大程度上有賴於 regexp 是否具有標誌 g。

如果 regexp 沒有標誌 g,那麼 match() 方法就只能在 stringObject 中執行一次匹配。如果沒有找到任何匹配的文本, match() 將返回 null。否則,它將返回一個數組,其中存放了與它找到的匹配文本有關的資訊。該數組的第 0 個元素存放的是匹配文本,而其餘的元素存放的是與Regex的子運算式匹配的文本。除了這些常規的數組元素之外,返回的數組還含有兩個對象屬性。index 屬性聲明的是匹配文本的起始字元在 stringObject 中的位置,input 屬性聲明的是對 stringObject 的引用。

如果 regexp 具有標誌 g,則 match() 方法將執行全域檢索,找到 stringObject 中的所有匹配子字串。若沒有找到任何匹配的子串,則返回 null。如果找到了一個或多個匹配子串,則返回一個數組。不過全域匹配返回的數組的內容與前者大不相同,它的數組元素中存放的是 stringObject 中所有的匹配子串,而且也沒有 index 屬性或 input 屬性。

注意:在全域檢索模式下,match() 即不提供與子運算式匹配的文本的資訊,也不聲明每個匹配子串的位置。如果您需要這些全域檢索的資訊,可以使用 RegExp.exec()。

參數為字串的案例:

複製代碼 代碼如下:var str="Hello world!"
document.write(str.match("world") + "<br />")

參數為Regex的案例: 複製代碼 代碼如下:var str="1 plus 2 equal 3"
document.write(str.match(/\d+/g))

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

stringObject.replace(regexp/substr,replacement)

參數 描述
regexp/substr

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

請注意,如果該值是一個字串,則將它作為要檢索的直接量文字模式,而不是首先被轉換為 RegExp 對象。

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

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

說明

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

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

字元 替換文本
$1、$2、...、$99 與 regexp 中的第 1 到第 99 個子運算式相匹配的文本。
$& 與 regexp 相匹配的子串。
$` 位於匹配子串左側的文本。
$' 位於匹配子串右側的文本。
$$ 直接量符號。

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

字串替換:複製代碼 代碼如下:var str="Visit Microsoft!"
document.write(str.replace(/Microsoft/, "W3School"))

全域替換: 複製代碼 代碼如下:var str="Welcome to Microsoft! "
str=str + "We are proud to announce that Microsoft has "
str=str + "one of the largest Web Developers sites in the world."
document.write(str.replace(/Microsoft/g, "W3School"))

返回的結果:Welcome to W3School! We are proud to announce that W3Schoolhas one of the largest Web Developers sites in the world.使用Regex: 複製代碼 代碼如下:name = '"a", "b"';
name.replace(/"([^"]*)"/g, "'$1'");

使用函數: 複製代碼 代碼如下:name = 'aaa bbb ccc';
uw=name.replace(/\b\w+\b/g, function(word){
return word.substring(0,1).toUpperCase()+word.substring(1);}
);

4:split() 方法用於把一個字串分割成字串數組。文法

stringObject.split(separator,howmany)

參數 描述
separator 必需。字串或Regex,從該參數指定的地方分割 stringObject。
howmany 可選。該參數可指定返回的數組的最大長度。如果設定了該參數,返回的子串不會多於這個參數指定的數組。如果沒有設定該參數,整個字串都會被分割,不考慮它的長度。

傳回值

一個字串數組。該數組是通過在 separator 指定的邊界處將字串 stringObject 分割成子串建立的。返回的數組中的字串不包括 separator 自身。

但是,如果 separator 是包含子運算式的Regex,那麼返回的數組中包括與這些子運算式匹配的字串(但不包括與整個Regex匹配的文本)。

提示和注釋

注釋:如果把Null 字元串 ("") 用作 separator,那麼 stringObject 中的每個字元之間都會被分割。

注釋:String.split() 執行的操作與 Array.join 執行的操作是相反的。

修飾符

修飾符 描述
i 執行對大小寫不敏感的匹配。
g 執行全域匹配(尋找所有匹配而非在找到第一個匹配後停止)。
m 執行多行匹配。

方括弧

方括弧用於尋找某個範圍內的字元:

運算式 描述
[abc] 尋找方括弧之間的任何字元。
[^abc] 尋找任何不在方括弧之間的字元。
[0-9] 尋找任何從 0 至 9 的數字。
[a-z] 尋找任何從小寫 a 到小寫 z 的字元。
[A-Z] 尋找任何從大寫 A 到大寫 Z 的字元。
[a-Z] 尋找任何從小寫 a 到大寫 Z 的字元。
[adgk] 尋找給定集合內的任何字元。
[^adgk] 尋找給定集合外的任何字元。
[red|blue|green] 尋找任何指定的選項。

元字元

元字元(Metacharacter)是擁有特殊含義的字元:

元字元 描述
. 尋找單個字元,除了換行和行結束符。
\w 尋找單詞字元。
\W 尋找非單詞字元。
\d 尋找數字。
\D 尋找非數字字元。
\s 尋找空白字元。
\S 尋找非空白字元。
\b 尋找位於單詞的開頭或結尾的匹配。
\B 尋找不處在單詞的開頭或結尾的匹配。
\0 尋找 NUL 字元。
\n 尋找分行符號。
\f 尋找換頁符。
\r 尋找斷行符號符。
\t 尋找定位字元。
\v 尋找垂直定位字元。
\xxx 尋找以八位元 xxx 規定的字元。
\xdd 尋找以十六進位數 dd 規定的字元。
\uxxxx 尋找以十六進位數 xxxx 規定的 Unicode 字元。

量詞

量詞 描述
n+ 匹配任何包含至少一個 n 的字串。
n* 匹配任何包含零個或多個 n 的字串。
n? 匹配任何包含零個或一個 n 的字串。
n{X} 匹配包含 X 個 n 的序列的字串。
n{X,Y} 匹配包含 X 或 Y 個 n 的序列的字串。
n{X,} 匹配包含至少 X 個 n 的序列的字串。
n$ 匹配任何結尾為 n 的字串。
^n 匹配任何開頭為 n 的字串。
?=n 匹配任何其後緊接指定字串 n 的字串。
?!n 匹配任何其後沒有緊接指定字串 n 的字串。

JavaScript RegExp 對象參考手冊

相關文章

聯繫我們

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