有兩種方式可以建立RegExp物件的實例。
使用RegExp的明確建構函數,語法為:new RegExp("pattern"[,"flags"])。
使用RegExp的隱式建構函數,採用純文字格式:/pattern/[flags]。
pattern部分為要使用的正規表示式模式文本,是必須的。在第一種方式中,pattern部分以JavaScript字串的形式存在,需要使用雙引號或單引號括起來;在第二種方式中,pattern部分嵌套在兩個「/」之間,不能使用引號。
flags部分設定正規表示式的標誌訊息,是可選項。如果設定flags部分,在第一種方式中,以字串的形式存在;在第二種方式中,以文字的形式緊接在最後一個「/」字元之後。 flags可以是以下標誌字元的組合。
g是全域標誌。如果設定了這個標誌,對某個文字執行搜尋和取代操作時,將對文字中所有符合的部分起作用。如果不設定這個標誌,則僅搜尋和取代最早匹配的內容。
i是忽略大小寫標誌。如果設定了這個標誌,進行配對比較時,將忽略大小寫。
m是多行標誌。如果不設定這個標誌,那麼元字元「^」只與整個被搜尋字串的起始位置相匹配,而元字元「$」只與被搜尋字串的結束位置相符。如果設定了這個標誌,「^」也可以與被搜尋字串中的「
”或“
」之後的位置(即下一行的行首)相匹配,而“$”還可以與被搜尋字串中的“
”或“
」之後的位置(即下一行的行尾)相符。
程式碼1.1是一個建立正規表示式的範例。
程式碼1.1 建立正規表示式:1.1.htm
建立正規表示式
上面程式碼的運行結果如圖8.1所示。正規表示式中的「」以「」取代。 🎜>
由於正則表達式模式文本中的轉義字符也是“”,如果正則表達式中要匹配原義字符“”,在正則表達式模式文本中要以“”來表示,當使用顯式構造函數的方式建立RegExp實例物件的時候,就需要使用「\」來表示原義字元「」。
var re = new RegExp(\\)。
1 RegExp物件的屬性
RegExp物件的屬性分為靜態屬性和實例屬性。以下分別進行介紹。
1.1 靜態屬性
(1)index屬性。是目前表達式模式首次符合內容的開始位置,從0開始計數。其初始值為-1,每次成功匹配時,index屬性都會隨之改變。
(2)input屬性。傳回目前所作用的字串,可以簡寫為$_,初始值為空字串""。
(3)lastIndex屬性。是當前表達式模式首次匹配內容中最後一個字元的下一個位置,從0開始計數,常被作為繼續搜索時的起始位置,初始值為-1,表示從起始位置開始搜索,每次成功匹配時,lastIndex屬性值都會隨之改變。
(4)lastMatch屬性。是目前表達式模式的最後一個符合字串,可以簡寫為$&。其初始值為空字串""。在每次成功配對時,lastMatch屬性值都會隨之改變。
(5)lastParen屬性。如果表達式模式中有括起來的子匹配,是當前表達式模式中最後的子匹配所匹配到的子字串,可以簡寫為$ 。其初始值為空字串""。每次成功配對時,lastParen屬性值都會隨之改變。
(6)leftContext屬性。是目前表達式模式最後一個符合字串左邊的所有內容,可以簡寫為$`(其中「'」為鍵盤上「Esc」下邊的反單引號)。初始值為空字串""。每次成功匹配時,其屬性值都會隨之改變。
(7)rightContext屬性。是目前表達式模式最後一個符合字串右邊的所有內容,可以簡寫為$'。初始值為空字串""。每次成功匹配時,其屬性值都會隨之改變。
(8)$1…$9屬性。這些屬性是唯讀的。如果表達式模式中有括起來的子匹配,$1…$9屬性值分別是第1個到第9個子匹配所捕捉到的內容。如果有超過9個以上的子匹配,$1…$9屬性分別對應最後的9個子匹配。在一個表達式模式中,可以指定任意多個括號的子匹配,但RegExp物件只能儲存最後的9個子匹配的結果。在RegExp實例物件的一些方法所傳回的結果陣列中,可以得到所有圓括號內的子符合結果。
1.2 實例屬性 (1)global屬性。傳回建立RegExp物件實例時指定的global標誌(g)的狀態。如果在建立RegExp物件實例時設定了g標誌,則該屬性傳回True,否則傳回False,預設值為False。
(2)ignoreCase屬性。傳回建立RegExp物件實例時指定的ignoreCase標誌(i)的狀態。如果在建立RegExp物件實例時設定了i標誌,則該屬性傳回True,否則傳回False,預設值為False。
(3)multiLine屬性。傳回建立RegExp物件實例時指定的multiLine標誌(m)的狀態。如果建立RegExp物件實例時設定了m標誌,則此屬性傳回True,否則傳回False,預設值為False。
(4)source屬性。傳回建立RegExp物件實例時指定的表達式文字字串。
JS中的RegExp物件(二)
2 RegExp物件的方法
RegExp物件的常用方法有test、exec物件和compile,本節介紹這些方法的功能和用法。最後,對RegExp物件的屬性和方法進行一個綜合舉例。
2.1 test方法 語法格式為test(str)。此方法檢查字串中是否存在建立RegExp物件實例時所指定的表達式模式,如果存在就傳回True,否則傳回False。如果找到符合項,則會更新RegExp物件中的相關靜態屬性,以反映符合情況。
2.2 exec方法
語法格式為exec(str)。此方法使用建立RegExp物件實例時所指定的表達式模式對一個字串進行搜索,並傳回一個包含搜尋結果的陣列。
如果為正規表示式設定了全域標誌(g),可以透過多次呼叫exec和test方法在字串中進行連續搜索,每次都是從RegExp物件的lastIndex屬性值指定的位置開始搜尋字符串。
如果沒有設定全域標誌(g),則exec和test方法忽略RegExp物件的lastIndex屬性值,從字串的起始位置開始搜尋。
如果exec方法沒有找到匹配,則傳回值為null;如果找到匹配,則傳回一個數組,並更新RegExp物件中有關靜態屬性以反映匹配情況。傳回數組中的元素0包含了完整的匹配結果,而元素1~n依序是表達式模式中定義的各個子匹配的結果。
exec方法傳回的陣列有3個屬性,分別是input、index和lastIndex。
input屬性是整個被搜尋的字串。
index屬性是指匹配在整個被搜尋字串中的位置。
lastIndex屬性是指匹配的子字串的最後一個字元的下一個字元位置。
代碼2.1是對此方法的應用舉例。 程式碼2.1 exec()方法應用:2.1.htm
複製程式碼🎜>
exec()方法應用
2.3 compile方法語法格式為compile("pattern"[,"flags"])。此方法可以更換RegExp物件實例所使用的表達式模式,並將新的表達式模式編譯為內部格式,從而使以後的匹配過程執行更快。如果要在迴圈中重複使用某個表達式,對其進行編譯將使執行加速。但是,如果在程式中使用了任何其他表達式模式後,再使用原來編譯過的表達式模式,則這種編譯毫無 益處。
2.4 綜合舉例 代碼2.2是對RegExp對象的綜合舉例,認真分析代碼及其運行結果,可以更好地理解RegExp對象。
程式碼2.2 RegExp物件的使用:2.2.htm
程式碼如下:
程式碼如下:
}