1-新建
1.使用字面量(常用)
var re = /a/;
2.RegExp構造函數
var re = new RegExp("a");
2-匹配方法
1.test():返回一個布爾值,方法用于匹配字符串,匹配成功返回true;返回失敗false;
console.log(re.text(str));
2.exec():返回匹配結果。,發現匹配,就返回一個以每個匹配成功的字符串
組成的數組,否則返回null。
console.log(re.exec(str));
方法屬性:
index 表示匹配想在字符串中的位置
input表示元字符串
3-匹配方法
- match()
接受一個參數,正則去匹配字符串,如果匹配成功就返回匹配成功的數組,如果匹配不成功,就返回null
2 . search()
參數與match相同,返回字符串,中的第一個匹配項的索引,沒有匹配項返回-1
3-replace()用于替換接受兩個參數,第一個是匹配項,第二個可以是字符串或是一個函數。
4-split 用指定的分隔符將一個字符串分割成多個子字符串,并將結果放在一個數組里。接受兩個參數,第一個為指定分隔符,第二個可選,用于指定數組的最大成員數(個別瀏覽器對該方法有不同解析,注意調試)
3-匹配規則
1-字面量字符 :在正則表達式中,某個字符只表示它字面的含義,比如/a/匹配a。
2-元字符:出字面量字符以外,還有一部分字符有特殊含義,不代表字面意思,叫“元字符”。如果要匹配它們本身,需要在他們面前加上反斜杠進行轉義,比如匹配加號,就要寫成 +
正則中需要斜杠轉義的字符:
^、.、[、]、$、(、)、|、*、+、?、{、}、\\ //
(1---點子符). : 匹配除回車\r 換行\n 行分隔符\u2028,段分割符\2029以外的所有字符
(2-位置字符):^表示字符串的開始位置;$表示字符串的結束位置
(3---豎線符號)| 在正則中表示“或關系”即a|b表示匹配a或b
如果使用RegExp方法生成正則對象,轉移需要使用李忙個斜杠,因為字符串內部會先轉義一次
3-重復類:
模式的精確匹配次數,用大括號{}表示。{n}表示恰好重復n次,{n,}表示至少重復n次,{n,m}表示重復不少于n次,不多于m次;
4-量詞符:
(?):問號表示某個模式出現出現0次或1次;等同于{0,1}
(*):星號表示某個模式出現0次或多次,等同于{0}
(+) :加號表示某個模式出現1次或多次,等同于{1}
5-字符類
表示有一系列字符可供選擇,只要匹配其中一個就可以,所有可供選擇的字符都放在方括號內,如【abc】表示a,b,c之中任選一個匹配
(1--脫字符)如果方括號內第一個字符是[].則表示除了字符串中的字符,其他字符都可以匹配,如:[abc]表示除了a.b.c之外都可以匹配。
(2--連字符-) 對于連續序列的字符,連字符用來提供簡寫形式,表示字符串的連續范圍,如:[abc]可寫成[a-c],[01234567889]可寫成[0-9],[A-Z]表示26個大寫字母
6-修飾符
修飾符b表示模式的附加規則,放在正則模式的最尾部,修飾符可以單個使用也可以多個使用
(1-g)g默認情況下,第一次匹配成功后正則對象就停止向下匹配,g修飾表示全局匹配
(2-i)默認情況下,正則對象區分字母大大小寫,加上i修飾符以后表示忽略大小寫
(3-m)表示多行模式,會修改和$的行為,默認情況下,和$匹配字符串的開始處和結尾處,加上m修飾符后,^和$會識別換行符\n
7-預定義模式:
指定某些常見模式的簡寫方式
(1)\d匹配0-9之間的任一數字,相當于[0-9]
(2)\D匹配所有0-9以外的字符,相當于[^0-9]
(3)\w匹配任意的字母,數字和下劃線,相當于[A-Za-z0-9_]
(4)\W匹配除字母,數字和下劃線,相當于[A-Za-z0-9]
(5)\s匹配空格,包括指標符,空格符,斷行符等
(6)\S匹配非空格的字符
(7)\b匹配單詞的邊界
(8)\B匹配非單詞的邊界
8-特殊字符
[\b] 匹配退格鍵
\n匹配換行鍵
\r匹配回車鍵
\f匹配換頁符
\t查找制表符tab
9匹配符
正則表達式的過好表示分組匹配,括號中的模式可以用來匹配分組的內容