Regex學習

來源:互聯網
上載者:User
正則

  Regex是regular expression,看來英文比中文要好理解多了,就是檢查運算式符 不符合規定!!Regex有一個功能十分強大而又十分複雜的對象RegExp,在Javascript1.2 版本以上提供。

  下面我們看看有關Regex的介紹:

  Regex對象用來規範一個規範的運算式(也就是運算式符不符合特定的要求,比如是不是Email地址格式等),它具有用來檢查給出的字串是否符合規則的屬性和方法。除此之外,你用RegExp構造器建立的個別Regex對象的屬性,就已經預先定義好了Regex對象的靜態屬性,你可以隨時使用它們。

  核心對象:
  在Javascript 1.2, NES 3.0以上版本提供。
  在Javascript 1.3以後版本增加了toSource方法。

  建立方法:

文字格式或RegExp構造器函數。
文字建立格式使用以下格式:
/pattern/flags即/模式/標記

構造器函數方法使用方法如下:
new RegExp("pattern"[, "flags"])即new RegExp("模式"[,"標記"])
參數:
pattern(模式)
表示Regex的文本

flags(標記)
如果指定此項,flags可以是下面值之一:
g: global match(全定匹配)
i: ignore case(忽略大小寫)
gi: both global match and ignore case(匹配所有可能的值,也忽略大小寫)

注意:文字格式設定中的參數不要使用引號標記,而構造器函數的參數則要使用引號標記。所以下面的
運算式建立同樣的Regex:
/ab+c/i
  new RegExp("ab+c", "i")

描述:
當使用建構函式的時候,必須使用正常的字串避開規則(在字串中加入前置字元\ )是必須的。
例如,下面的兩條語句是等價的:
re = new RegExp("\\w+")
re = /\w+/

下面的提供了在Regex中能夠使用的完整對特殊字元的一個完整的列表和描述。

表1.3:Regex中的特殊字元:

字元\
意義:對於字元,通常表示按字面意義,指出接著的字元為特殊字元,\不作解釋。
例如:/b/匹配字元'b',通過在b 前面加一個反斜線\,也就是/\b/,則該字元變成特殊字元,表示
匹配一個單詞的分界線。
或者:
對於幾個字元,通常說明是特殊的,指出緊接著的字元不是特殊的,而應該按字面解釋。
例如:*是一個特殊字元,匹配任意個字元(包括0個字元);例如:/a*/意味匹配0個或多個a。
為了匹配字面上的*,在a前面加一個反斜線;例如:/a\*/匹配'a*'。

字元^
意義:表示匹配的字元必須在最前邊。
例如:/^A/不匹配"an A,"中的'A',但匹配"An A."中最前面的'A'。

字元$
意義:與^類似,匹配最末的字元。
例如:/t$/不匹配"eater"中的't',但匹配"eat"中的't'。

字元*
意義:匹配*前面的字元0次或n次。
例如:/bo*/匹配"A ghost booooed"中的'boooo'或"A bird warbled"中的'b',但不匹配"A goat g
runted"中的任何字元。

字元+
意義:匹配+號前面的字元1次或n次。等價於{1,}。
例如:/a+/匹配"candy"中的'a'和"caaaaaaandy."中的所有'a'。

字元?
意義:匹配?前面的字元0次或1次。
例如:/e?le?/匹配"angel"中的'el'和"angle."中的'le'。

字元.
意義:(小數點)匹配除分行符號外的所有單個的字元。
例如:/.n/匹配"nay, an apple is on the tree"中的'an'和'on',但不匹配'nay'。


字元(x)
意義:匹配'x'並記錄匹配的值。
例如:/(foo)/匹配和記錄"foo bar."中的'foo'。匹配子串能被結果數組中的素[1], ..., [n] 返
回,或被RegExp對象的屬性$1, ..., $9返回。

字元x|y
意義:匹配'x'或者'y'。
例如:/green|red/匹配"green apple"中的'green'和"red apple."中的'red'。

字元{n}
意義:這裡的n是一個正整數。匹配前面的n個字元。
例如:/a{2}/不匹配"candy,"中的'a',但匹配"caandy," 中的所有'a'和"caaandy."中前面的兩個
'a'。

字元{n,}
意義:這裡的n是一個正整數。匹配至少n個前面的字元。
例如:/a{2,}不匹配"candy"中的'a',但匹配"caandy"中的所有'a'和"caaaaaaandy."中的所有'a'

字元{n,m}
意義:這裡的n和m都是正整數。匹配至少n個最多m個前面的字元。
例如:/a{1,3}/不匹配"cndy"中的任何字元,但匹配 "candy,"中的'a',"caandy," 中的前面兩個
'a'和"caaaaaaandy"中前面的三個'a',注意:即使"caaaaaaandy" 中有很多個'a',但只匹配前面的三
個'a'即"aaa"。

字元[xyz]
意義:一字元列表,匹配列出中的任一字元。你可以通過連字號-指出一個字元範圍。
例如:[abcd]跟[a-c]一樣。它們匹配"brisket"中的'b'和"ache"中的'c'。

字元[^xyz]
意義:一字元補集,也就是說,它匹配除了列出的字元外的所有東西。 你可以使用連字號-指出一
字元範圍。
例如:[^abc]和[^a-c]等價,它們最早匹配"brisket"中的'r'和"chop."中的'h'。

字元[\b]
意義:匹配一個空格(不要與\b混淆)

字元\b
意義:匹配一個單詞的分界線,比如一個空格(不要與[\b]混淆)
例如:/\bn\w/匹配"noonday"中的'no',/\wy\b/匹配"possibly yesterday."中的'ly'。

字元\B
意義:匹配一個單詞的非分界線
例如:/\w\Bn/匹配"noonday"中的'on',/y\B\w/匹配"possibly yesterday."中的'ye'。

字元\cX
意義:這裡的X是一個控制字元。匹配一個字串的控制字元。
例如:/\cM/匹配一個字串中的control-M。

字元\d
意義:匹配一個數字,等價於[0-9]。
例如:/\d/或/[0-9]/匹配"B2 is the suite number."中的'2'。

字元\D
意義:匹配任何的非數字,等價於[^0-9]。
例如:/\D/或/[^0-9]/匹配"B2 is the suite number."中的'B'。

字元\f
意義:匹配一個表單符

字元\n
意義:匹配一個分行符號

字元\r
意義:匹配一個斷行符號符

字元\s
意義:匹配一個單個white空格符,包括空格,tab,form feed,分行符號,等價於[ \f\n\r\t\v]。
例如:/\s\w*/匹配"foo bar."中的' bar'。

字元\S
意義:匹配除white空格符以外的一個單個的字元,等價於[^ \f\n\r\t\v]。
例如:/\S/\w*匹配"foo bar."中的'foo'。

字元\t
意義:匹配一個定位字元

字元\v
意義:匹配一個頂頭定位字元

字元\w
意義:匹配所有的數字和字母以及底線,等價於[A-Za-z0-9_]。
例如:/\w/匹配"apple,"中的'a',"$5.28,"中的'5'和"3D."中的'3'。

字元\W
意義:匹配除數字、字母外及底線外的其它字元,等價於[^A-Za-z0-9_]。
例如:/\W/或者/[^$A-Za-z0-9_]/匹配"50%."中的'%'。

字元\n
意義:這裡的n是一個正整數。匹配一個Regex的最後一個子串的n的值(計數左圓括弧)。

例如:/apple(,)\sorange\1/匹配"apple, orange, cherry, peach."中的'apple, orange',下面
有一個更加完整的例子。
注意:如果左圓括弧中的數字比\n指定的數字還小,則\n取下一行的八進位escape作為描述。

字元\ooctal和\xhex
意義:這裡的\ooctal是一個八進位的escape值,而\xhex是一個十六進位的escape值,允許在一個
Regex中嵌入ASCII碼。


當運算式被檢查的時候,文字元號提供了編輯Regex的方法。利用文字元號可以使到正則表達
式保持為常數。例如,如果你在一個迴圈中使用文字元號來構造一個Regex,Regex不需進行
反覆編譯。
Regex物件建構器,例如,new RegExp("ab+c"),提供Regex的運行時編譯。當你知道正
則運算式的模式會變化的時候,應該使用建構函式,或者你不知道Regex的模式,而它們是從另外
的源獲得的時候,比如由使用者輸入時。一旦你定義好了Regex,該Regex可在任何地方使用,
並且可以改變,你可以使用編譯方法來編譯一個新的Regex以便重新使用。
一個分離預先定義的RegExp對象可以在每個視窗中使用;也就是說,每個分離的Javascript線程運
行以獲得自己的RegExp對象。因為每個指令碼在一個線程中是不可中斷的,這就確保了不同的指令碼不會覆
蓋RegExp對象的值。
預定義的RegExp對象包含的靜態屬性:input, multiline, lastMatch,lastParen, leftContext,
rightContext, 以及從$1到$9。input和multiline屬效能被預設。其它靜態屬性的值是在執行個別正則
運算式對象的exec和test方法後,且在執行字串的match和replace方法後設定的。

屬性
注意RegExp對象的幾個屬性既有長名字又有短名字(象Perl)。這些名字都是指向相同的值。Perl是
一種程式設計語言,而Javascript模仿了它的Regex。

屬性$1, ..., $9
取得匹配的子串,如果有的話

屬性$_
參考input

屬性$*
參考multiline

屬性$&
參考lastMatch

屬性$+
參考lastParen

屬性$`
參考leftContext

屬性$'
參考rightContext

屬性constructor
指定用來建立對象原型函

屬性global
決定是否測試Regex是否不能匹配所有的字串,或者只是與最先的衝突。

屬性ignoreCase
決定試圖匹配字串的時候是否忽略大小寫

屬性input
當Regex被匹配的時候,為相反的字串。

屬性lastIndex
決定下一次匹配從那裡開始

屬性lastMatch
最後一個匹配的字元

屬性lastParen
子串匹配的時候,最後一個parenthesized,如果有的話。

屬性leftContext
最近一次匹配前的子串。

屬性multiline
是否在串的多行中搜尋。

屬性prototype
允許附加屬性到所有的對象

屬性rightContext
最近一次匹配後的的子串。

屬性source
模式文本

方法
compile方法
編譯一個Regex對象

exec方法
運行Regex匹配

test方法
測試正則達式匹配

toSource方法
返回一個對象的文字描述指定的對象;你可以使用這個值來建立一個新的對象。不考慮Object.toS
ource方法。

toString方法
返回一個字串描述指定的對象,不考慮Object.toString對象。

valueOf方法
返回指定對角的原始值。不考慮Object.valueOf方法。

 另外,這個對象繼承了對象的watch和unwatch方法

  例子:
  例1、下述樣本指令碼使用replace方法來轉換串中的單詞。在替換的文本中,指令碼使用全域 RegExp
對象的$1和$2屬性的值。注意,在作為第二個參數傳遞給replace方法的時候,RegExp對象的$屬性的名
稱。
<script LANGUAGE="Javascript1.2">
re = /(\w+)\s(\w+)/;
str = "John Smith";
newstr=str.replace(re,"$2, $1");
document.write(newstr)
</script>
顯示結果:"Smith, John".

  例2、下述樣本指令碼中,RegExp.input由Change事件處理控制代碼設定。在getInfo函數中,exec 方法
使用RegExp.input的值作為它的參數,注意RegExp預置了$屬性。


<script LANGUAGE="Javascript1.2">
function getInfo(abc)
{
re = /(\w+)\s(\d+)/;
re.exec(abc.value);
window.alert(RegExp.$1 + ", your age is " + RegExp.$2);
}
</script>

  請輸入你的姓和年齡,輸入完後按斷行符號鍵。
  <FORM><INPUT TYPE="TEXT" NAME="NameAge" ></FORM>
  </HTML>


$1, ..., $9屬性
用圓括弧括著的匹配子串,如果有的話。
是RegExp的屬性
靜態,唯讀

在Javascript 1.2, NES 3.0以上版本提供
描述:因為input是靜態屬性,不是個別Regex對象的屬性。你可以使用RegExp.input 訪問該
屬性。

能加上圓括弧的子串的數量不受限制,但Regex對象只能保留最後9 條。如果你要訪問所有的
圓括弧內的匹配字串,你可以使用返回的數組。

這些屬效能用在RegExp.replace方法替換後的字串(輸出結果)。當使用這種方式的時候,不用預
先考慮RegExp對象。下面給出例子。當Regex中沒有包含圓括弧的時候,該指令碼解釋成$n的字面意
義。(這裡的n是一個正整數)。


例如:
下例指令碼使用replace 方法來交換串中單詞的位置。在替換後的文本字串中,指令碼使用Regex
RegExp對象的$1和$2屬性的值。注意:當它們向replace方法傳遞參數的時候,這裡沒有考慮 $ 屬性的
RegExp對象的名稱。
<script LANGUAGE="Javascript1.2">
re = /(\w+)\s(\w+)/;
str = "John Smith";
newstr=str.replace(re,"$2, $1");
document.write(newstr)
</script>
顯示的輸出結果為:Smith, John。

<<<<<<<Regex詳述>>>>>>>

以下這些不是Regex的新增對象請參閱對應的Javascript對象的屬性 $_屬性 參考input $*屬性
參考multiline $&屬性 參考lastMatch $+屬性 參考lastParen $`屬性
參考leftContext $'屬性 參考rightContext compile方法 在指令碼運行期間編譯Regex對象
屬於RegExp的方法 在Javascript 1.2, NES 3.0以上版本提供 文法:
regexp.compile(pattern[, flags]) 以數: regexp Regex的名稱,可以是變數名或文字串。
pattern Regex的定義文本。 flags 如果指定的話,可以是下面其中的一個: "g": 匹配所有可能的字串
"i": 忽略大小寫 "gi": 匹配所有可能的字串及忽略大小寫 描述:
使用compile方法來編譯一個Regex created with the RegExp constructor function。這樣
就強制Regex只編譯一次,而不是每次遇到Regex的時候都編譯一次。當你確認Regex能
保持不變的時候可使用compile 方法來編譯它(在獲得它的匹配模式後),這樣就可以在指令碼中重複多次使用它。
你亦可以使用compile 方法來改變在運行期間改變Regex。例如,假如Regex發生變化,
你可以使用compile方法來重新編譯該對象來提高使用效率。
使用該方法將改變Regex的source, global和ignoreCasesource屬性的值。 constructor
指出建立對象原型的function。注意這個屬性的值由函數本身提供,而不是一個字串包含RegExp的name.Property提供。
在Javascript 1.1, NES 2.0以上版本提供 ECMA版本ECMA-262 描述:參考Object.constructor.
exec方法 在指定的字串運行匹配搜尋。返回一個結果數組。 是RegExp的方法
在Javascript 1.2, NES 3.0以上版本提供 文法: regexp.exec([str])regexp([str])
參數: regexp,Regex的名稱,可以是一個變數名或文字定義串。
str,要匹配Regex的字串,如果省略,將使用RegExp.input的值。
描述:就如在文法描述中的一樣,正則表達工的exec方法能夠被直接調用(使用regexp.exec(str))或者間接調用(使用regexp(str))。
假如你只是運行以找出是否匹配,可以使用String搜尋方法。
假如匹配成功,exec方法返回一個數組並且更新Regex對象屬性的值和預先定義的Regex對象、RegExp。如果匹配失敗,exec方法返回null。
請看下例: <script LANGUAGE="Javascript1.2"> file://匹配一個b接著一個或多個d,再接著一個b
file://忽略大小寫 myRe=/d(b+)(d)/ig; myArray = myRe.exec("cdbBdbsbz");
</script> 下面是該指令碼的傳回值:對象 屬性/Index 描述 例子
myArray

myArray的內容 ["dbBd", "bB", "d"]
index
基於0的匹配index 1
input
原始字串 cdbBdbsbz
[0]
最後匹配的字元 dbBd
[1], ...[n]
用圓括弧括住的匹配字串,如果有的話。不限制括弧的個數。 [1] = bB
[2] = d
myRe
lastIndex
開始下次匹配操作的index值 5
ignoreCase
指出"i"是否使用以忽略大小寫 true
global
指出是否使用"g"標記來進行匹配所有可能的字串 true
source
定義模式的文本字串 d(b+)(d)
RegExp
lastMatch$&
最後匹配的字元 dbBd
leftContext$\Q
最新匹配前面的子串 c
rightContext$'
最新匹配後面的子串 bsbz
$1, ...$9
圓括弧內的匹配子串,如果有的話。圓括弧的個數不受限制,但RegExp只能保留最後9個 $1 = bB
$2 = d
lastParen $+
最後一個加上圓括弧的匹配子串,如果有的話 d

假如你的Regex使用了"g"標記,你可以多次使用exec 方法來連續匹配相同的串。當你這樣做
的時候,新的匹配將從由Regex的lastIndex 屬性值確定的子串中開始。例如,假定你使用下面的指令碼:
<script LANGUAGE="Javascript1.2"> myRe=/ab*/g;str = "abbcdefabh"
myArray = myRe.exec(str);
document.writeln("Found "+myArray[0]+". Next match starts at "+myRe.lastIndex)
mySecondArray = myRe.exec(str);
document.writeln("Found "+mySecondArray[0]+". Next match starts at "+myRe.lastIndex)
</script> 這個指令碼顯示如下結果: Found abb. Next match starts at 3
Found ab. Next match starts at 9 例子:
在下面的例子中,使用者輸入一個名字,指令碼根據輸入執行匹配操作。接著檢查數組看是否和其它使用者的名字匹配。
本指令碼假定已註冊的使用者的姓已經存進了數組A中,或許從一個資料庫中取得。 <HTML>
<script LANGUAGE="Javascript1.2"> A = ["zhao","qian","sun","li","liang"]
function lookup() { firstName = /\w+/i(); if (!firstName)
window.alert (RegExp.input + "非法輸入"); else { count=0;
for (i=0;i 輸入你的姓然後按斷行符號鍵。
<FORM><INPUT TYPE:"TEXT" NAME="FirstName" ></FORM>
</HTML> global屬性 Regex中是否使用了"g"標記。 RegExp屬性,唯讀
在Javascript 1.2, NES 3.0以上版本提供 描述: global是一個個別Regex對象的屬性
如果使用了"g"標記,global的值為true;否則為 false。"g"標記指定Regex測試所有可能的匹配。
你不能直接改變該屬性的值,但可以調用compile方法來改變它。 ignoreCase 檢查Regex是否使用了"i"標記
RegExp屬性,唯讀 在Javascript 1.2, NES 3.0以上版本提供 描述:
ignoreCase是個別Regex對象的一個屬性。
如果使用了"i"標記,則返回true,否則返回false。"i"標記指示在進行匹配的時候忽略大小寫。
你不能直接改變該屬性的值,但可以通過調用compile方法來改變它 input 指出Regex要測試那個字串。$_是這個屬性的另一個名字。
RegExp的屬性,靜態 在Javascript 1.2, NES 3.0以上版本提供
描述:因為input是靜態,不是某個個別的Regex對象的屬性。你也可以使用 RegExp.input來表示。
如果沒有給Regex的exec或test方法提供字串,並且RegExp.input中有值,則使用它的值來調用該方法。
指令碼或瀏覽器能夠預置input屬性。如果被預置了值且調用exec或 test方法的時候沒有提供字串
則調用exec或test的時候使用input的值。input可以被瀏覽器以下面的方式設定:
當text表單域處理控制代碼被調用的時候,input被設定為該text輸入的字串。
當textarea表單域處理控制代碼被調用的時候,input被設定為textarea域內輸入的字串。注意multili
ne亦被設定成true從而能匹配多行文本。 當select表單域處理控制代碼被調用的時候,input被設定成selected text的值。
當連結化物件的處理控制代碼被調用的時候,input被設定成<A HREF=...>和</A>之間的字串。
事件理現控制代碼處理完畢後,input屬性的值被清除。 lastIndex 可讀/可寫的一個整數屬性,指出下一次匹配從哪裡開始。
RegExp的屬性 在Javascript 1.2, NES 3.0以上版本提供
描述:lastIndex 是個別的Regex對象的屬性。 這個屬性只有當Regex的"g"標記被使用以進行全串匹配的時候才被設定。實行以下規則:
如果lastIndex大小字串的長度,regexp.test和regexp.exec失敗,且lastIndex被設為0。
如果lastIndex等於字串的長度且Regex匹配Null 字元串,則Regex從lastIndex的位置開始匹配。
如果lastIndex等於字串的長度且Regex不匹配Null 字元串,則Regex不匹配input,且lastIndex被置為0。
否則,lastIndex被設定成最近一次匹配的下一點。 例如,按下面的順序執行指令碼: re = /(hi)?/g 匹配Null 字元串
re("hi") 返回["hi", "hi"],lastIndex置為2
re("hi") 返回[""],一個空數組,它的下標為0的元素就是匹配字串。在這種情況下,返回空
串是因為lastIndex等於2(且仍然是2),並且"hi"的長度也是2。 lastMatch 最後一次匹配字串,$&是同樣的意思。
RegExp的屬性,靜態,唯讀 在Javascript 1.2, NES 3.0以上版本提供
描述:因為lastMatch是靜態,所以它不是個別指定Regex的屬性。你也可以使用RegExp.lastMatch。 lastParen
最後一次加上括弧的匹配字串,如果有的話。$+是同樣的意思。 RegExp屬性,靜態,唯讀
在Javascript 1.2, NES 3.0以上版本提供
描述:因為lastParen是靜態,它不是某個個別正則式的屬性,你可以使用RegExp.lastParen 表達同樣的意思。
leftContext 最近一次匹配前面的子串,$`具有相同的意思。 RegExp的屬性,靜態,唯讀
在Javascript 1.2, NES 3.0以上版本提供
描述:因為leftContext是靜態,不是某一個Regex的屬性,所以可以使用RegExp.leftContext來表達想同的意思。
multiline 反映是否匹配多行文本,$*是相同的意思。 RegExp的屬性,靜態
在Javascript 1.2, NES 3.0以上版本提供
描述:因為multiline是靜態,而不是某個個別Regex的屬性,所以能夠用RegExp.multiline表達相同的意思。
如果允許匹配多行文本,則multiline為true,如果搜尋必須在換行時停止,則為false。
指令碼或瀏覽器能夠設定multiline屬性。當一個textarea的事件處理控制代碼被調用的時候,multiline
被置為true。在事件處理控制代碼處理完畢後,multiline屬性值被清除。也就是說,如果你設定了multili
ne為true,則執行任何的事件處理控制代碼後,multiline被置為false。 prototype
描繪類的原型。你可以根據要求使用prototype來增加類的屬性或方法。為了獲得prototypes 的資
料,請參閱RegExp的function.prototype.Property屬性。 從Javascript 1.1, NES 2.0版本開始提供
ECMA版本ECMA-262 rightContext 最後一次匹配的右邊的字串,$'是同樣的效果。
RegExp的屬性,靜態,唯讀 從 Javascript 1.2, NES 3.0以上版本開始提供
描述:因為rightContext是靜態,不是某個個別正則表達工的屬性,可以使用RegExp.rightContext來達到相同的效果。
source 一個唯讀屬性,包含Regex定義的模式,不包僑forward slashes和"g"或"i"標記。 RegExp的屬性,唯讀
從Javascript 1.2, NES 3.0以上版本開始提供
描述:source是個別Regex對象的屬性,你不能直接改變它的值,但可以通過調用compile 方法來改變它。 test
執行指定字串的Regex匹配搜尋,返回true或false。 RegExp的方法
從Javascript 1.2, NES 3.0以上版本開始提供 文法:regexp.test([str])
參數:regexp,Regex的名稱,可以是變數名或Regex定義文字串
str,要匹配的字串,如果省略,將使用RegExp.input的值為作參數
描述:當你需要知道一個字串能否匹配某個正則表達工,可以使用test方法(與String.search方
法類似); 為了獲得更多的資訊(但速度將變慢),可以使用exec方法(與String.match方法類似)。 例子:下面的例子顯示test是否成功的提示:
function testinput(re, str){
if (re.test(str)) midstring = " contains ";
else midstring = " does not contain ";
document.write (str + midstring + re.source); } toSource
返回一個字串象徵對象的源碼 RegExp的方法 從Javascript 1.3以上版本開始提供 文法:toSource()
參數:沒有 描述:toSource方法返回下述的值: 對於內建的RegExp對象,toSource返回下面的字元象徵源碼不可用:
function Boolean(){ [native code] }
在RegExp場合中, toSource返回象徵源碼的字串,通常這個方法是由Javascript內部自動調用而不是不代碼中顯式調用。
更多請看Object.toSource toString 返回描繪指定對象的字串。 RegExp的方法
從Javascript 1.1, NES 2.0開始提供 ECMA版本ECMA-262 文法:toString() 參數:無
描述:RegExp對象不考慮Object對象的toString方法;它不繼承Object.toString,對於RegExp 對
象,toString方法返回一個代表該對象的字串。 例如:下面的例子顯示象徵RegExp對象的字串
myExp = new RegExp("a+b+c"); alert(myExp.toString())
displays "/a+b+c/" 更多請看:Object.toString valueOf 返回一個RegExp對象的原始值
RegExp的方法 從Javascript 1.1版本開始提供 ECMA版本:ECMA-262 文法:valueOf()
參數:無 描述:RegExp的valueOf方法以字串形式返回RegExp對象的原始值,這個值與RegExp.toString相等。
該方法通常由Javascript內部自動調用而不是顯式調用 例子: myExp = new RegExp("a+b+c");
alert(myExp.valueOf()) displays "/a+b+c/"



相關文章

Beyond APAC's No.1 Cloud

19.6% IaaS Market Share in Asia Pacific - Gartner IT Service report, 2018

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

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

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