正則表達式是一個很牛逼的東東,今天在這里只是簡單的給剛剛接觸JS的人普及一下,里面若有爭議的地方歡迎大家留言!
1.1 什么是正則表達式
? 正則表達式(regular expression)是一個描述字符模式的對象,ECMAScript的RegExp 類表示正則表達式,而String和RegExp都定義了使用正則表達式進行強大的模式匹配和文本檢索與替換的函數。
? 正則表達式用于對字符串模式匹配及檢索替換,是對字符串執行模式匹配的強大工具。
1.2 正則表達式的作用
? 正則表達式主要用來驗證客戶端的輸入數據。
? 用戶填寫完表單單擊按鈕之后,表單就會被發送到服務器,在服務器端通常會用PHP、ASP.NET、JSP等服務器腳本對其進行進一步處理。因為客戶端驗證,可以節約大量的服務器端的系統資源,并且提供更好的用戶體驗。
二、創建正則表達式==(123)==
要使用正則表達式,必須先創建正則表達式對象,有2種創建對象的方式:
2.1 方式1:使用關鍵字new創建
var patt = new RegExp(pattern,modifiers);
參數1:正則表達式的模式。字符串形式
參數2:模式修飾符。用于指定全局匹配、區分大小寫的匹配和多行匹配
<script type="text/javascript"> /* 創建了一個正則表達式 參數1:模式是:girl,意思是說可以匹配 "girl"這樣的字符串 參數2:模式修飾符:gi g代表全局匹配 i代表不區分大小寫 */ var pa = new RegExp("girl", "gi"); //測試參數中的字符串"你好我的girl" 是否與匹配模式匹配。 var isExist = pa.test("你好我的girl"); // 在本例中,是匹配的,這個字符串包含girl,所以返回true alert(isExist); //true</script>
2.2 方式2:使用正則表達式直接量
var pa = /pattern/modifiers;
兩個/中間的表示正則表達式的模式,最后一個/的后面是模式修飾符
例如:上面的例子可以這樣寫 var pa = /girl/gi;
注意:這個時候模式和模式修飾符都能再添加雙引號或單引號
<script type="text/javascript"> var pa = /girl/gi; alert(pa.test("厲害了我的girl")); //true</script>
三、正則表達式模式修飾符==(126)==
JavaScript中共有3種模式修飾符:g i u
四、正則表達式方法詳解==(127)==
經常用到的正則表達式方法有兩個test() 和 exec()
4.1 test()方法
test(字符串)
在只想知道目標字符串與某個模式是否匹配,但不需要知道其文本內容的情況下,使用這個方法非常方便。因此, test() 方法經常被用在 if 語句中。
<script type="text/javascript"> var pa = /girl/gi; if(pa.test("厲害了我的girl")){ alert("這個女孩和你很配"); }else { alert("你注定沒有女孩去匹配"); }</script>
4.2 exec()方法
exec(字符串):該方法為專門為捕獲組而設計的
<script type="text/javascript"> var pa = /girl/gi; var testStr = "myGirl, yourgirl, hisgIrl"; var girls = pa.exec(testStr); //捕獲 alert(girls.length + ":" + (girls instanceof Array)); //正則表達式沒有捕獲組,所以數組長度為1 alert(girls[0]); //第一次捕獲的是 Girl //因為我們是用的全局匹配,所以此次匹配的時候從上次匹后的位置開始繼續匹配 alert(pa.exec(testStr)[0]); // girl alert(pa.exec(testStr)); // gIrl alert(pa.exec(testStr)); //繼續向后沒有匹配的字符串,所以返回null // 返回null,如果繼續再匹配,則會回到字符串的開始,重寫開始匹配。 alert(pa.exec(testStr)); // Girl // ...開啟新一輪匹配</script>
所以我們如果想找到全部匹配的字符串可以時候用循環,結束條件就是匹配結果為null
<script type="text/javascript"> var pa = /girl/gi; var testStr = "myGirl, yourgirl, hisgIrl"; var girls; while(girls = pa.exec(testStr)){ //如果等于null,會自動轉成 false,結束。 alert(girls); }</script>
分組。在正則表達式中用()括起來任務是一組。組可以嵌套。
<script type="text/javascript"> //()內的內容就是第1組(Girl),其實我們完整真個表達式可以看出第0組 girl(Girl) // 將來對應著匹配結果數組的下標。 var pa = /girl(Girl)/gi; var test = "girlGirl abdfjla Girlgirl fal girl"; var girls; while(girls = pa.exec(test)){ //匹配之后,數組的第0個元素對應的這第0組的匹配結果,第1個元素對應著第1組的匹配結果 for (var i = 0; i < girls.length; i++) { console.log(girls[i]); } console.log("-------------"); }</script>//最終運行結果:girlGirlGirl-------------Girlgirlgirl------------
五、正則表達式規則==(124)==
表達式規則
正則表達式元字符是包含特殊含義的字符。它們有一些特殊功能,可以控制匹配模式的
方式。反斜杠后的元字符將失去其特殊含義。
字符類:單個字符和數字
[0-9A-Za-z]
元字符/元符號 匹配情況
. 匹配除換行符外的任意字符
[a-z0-9] 匹配括號中的字符集中的任意字符
[^a-z0-9] 匹配任意不在括號中的字符集中的字符
/d ==[0-9] 匹配數字
/D ==[^0-9] 匹配非數字,同[^0-9]相同
/w [0-9A-Za-z_] 匹配字母和數字及_
/W 匹配非(字母和數字及_)
字符類:空白字符
元字符/元符號 匹配情況
/0 匹配null 字符
/b 匹配空格字符
/n 匹配換行符
/r 匹配回車字符
/t 匹配制表符
/s 匹配空白字符、空格、制表符和換行符
/S 匹配非空白字符
字符類:錨字符
元字符/元符號 匹配情況
^ 行首匹配
$ 行尾匹配
字符類:重復字符
元字符/元符號 匹配情況
? 例如(x?) 匹配0個或1 個x
* 例如(x*) 匹配0個或任意多個x
+ 例如(x+) 匹配至少一個x
(xyz)+ 匹配至少一個(xyz)
{m,n} 例如x{m,n} n>=次數>=m 匹配最少m個、最多n個x
{n} 匹配前一項n次
{n,} 匹配前一項n次,或者多次
六、常用正則表示==(128)==
1、檢查郵政編碼
var pattern = /[1-9][0-9]{5}/; //共6位數字,第一位不能為0var str = '224000';alert(pattern.test(str));
2、檢查文件壓縮包
var pattern = /[/w]+/.zip|rar|gz/; ///w 表示所有數字和字母加下劃線var str = '123.zip'; ///.表示匹配.,后面是一個選擇alert(pattern.test(str));
3、刪除多余空格
var pattern = //s/g; //g 必須全局,才能全部匹配var reg=new RegExp('//s+','g');var str = '111 222 333';var result = str.replace(pattern,''); //把空格匹配成無空格alert(result);
4、刪除空格
var pattern = /^/s+/; var str = ' goo gle ';alert(str+" "+str.length);var result = str.replace(pattern, '');alert(result+" "+result.length);pattern = //s+$/; result = result.replace(pattern, '');alert(result+" "+result.length);pattern = //s+/g; result = result.replace(pattern, '');alert(result+" "+result.length);5、簡單的電子郵件驗證var pattern = /^([a-zA-Z0-9_/./-]+)@([a-zA-Z0-9_/./-]+)/.([a-zA-Z]{2,4})$/;var str = 'yc60.com@gmail.com';alert(pattern.test(str));var pattern = /^([/w/./-]+)@([/w/./-]+)/.([/w]{2,4})$/;var str = 'yc60.com@gmail.com';alert(pattern.test(str));
七、支持正則表達式的字符串方法
方法 | 描述 |
---|---|
search | 檢索與正則表達式相匹配的第一個匹配項的索引。 |
match | 找到一個或多個正則表達式的匹配。 |
replace | 替換與正則表達式匹配的子串。 |
split | 把字符串分割為字符串數組。 |
<script type="text/javascript"> var s = "Abc123aBc"; alert(s.search(/abc/gi)); alert(s.search(/abc/gi)); // 即使設置的全局模式,每次search也是從開始向后查找 //match方法和正則表達式的exec()方法的作用是一樣的,但是match會一次性把所有的匹配放在一個數組中,全部返回 alert(s.match(/abc/gi)); // Abc,aBc alert(s.replace(/[ab]/gi, "x")); //把a或b替換成x var ss = s.split(/[0-9]+/gi); //用1個或多個數字切割。 Abc,aBc alert(ss);</script>
以上所述是小編給大家介紹的JS基礎系列之正則表達式,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VEVB武林網網站的支持!
新聞熱點
疑難解答