好好學一遍JavaScript 筆記(七)——RegExp對象與常用正則

來源:互聯網
上載者:User

javaScript RegExp對象:
global——Boolean值、表示g(全域選項)是否已設定
ignoreCase——Boolean值、表示i(忽略大小寫選項)是否已設定
lastIndex——整數、代表下次匹配將會從哪個字元位置開始(只有當使用exec()或test()函數才會填入、否則為0)
multiline——Boolean值、表示m(多行模式選項)是否已設定
source——Regex的源字串形式。例如、運算式/[ba]*/的source將返回"[ba]*"。
一般不會使用global、ignoreCase、multiline和source屬性、因為一般之前就已知道了這些資料。
真正有用的屬性是lastIndex、它可以告訴你Regex在某個字串中停止之前、尋找了多遠。
[javascript]
var sToMatch = "bbq is short for barbecue";  
var reB = /b/g;  
reB.exec(sToMatch);    
alert(reB.lastIndex);    //out: 1  
reB.exec(sToMatch);    
alert(reB.lastIndex);    //out: 2   
reB.exec(sToMatch);    
alert(reB.lastIndex);    //out: 18  
reB.exec(sToMatch);    
alert(reB.lastIndex);    //out: 21   
RegexreB尋找的是b。當它首次檢測sToMatch時、
它發現在第一個位置——也就是位置0——是b;
因此、lastIndex屬性就被設定成1、
而再次調用exec()時就從這個地方開始執行。
再次調用exec()、運算式在位置1又發現了b、
於是將lastIndex設值為2.第三次調用時、發現b在位置17、
於是又將lastIndex設值為18、如此繼續。
如果想從頭開始匹配、則可以將lastIndex設為0。
靜態屬性:
[javascript]
/** 
  * 它們都有兩個名字:一個複雜名字和一個以貨幣符號開頭的簡短名字。 
  * 長名        短名     描述 
  * input        $_     最後用於匹配的字串(傳遞給exec()或test()的字串) 
  * lastMatch    <span><span class="comment">$&</span></span>     最後匹配的字元 
  * lastParen    $+     最後匹配的分組 
  * leftContext  $`     在上次匹配的前面的子串 
  * multiline    $*     用於指定是否所有運算式都使用多行模式的布爾值 
  * rightContext $'     在上次匹配之後的子串 
  */  
 var sToMatch = "古道西風瘦馬、夕陽西下、斷腸人在天涯!";    
 var reB = /(西)風/g;  
 reB.test(sToMatch);  
 alert(RegExp.$_);  //out:古道西風瘦馬、夕陽西下、斷腸人在天涯!  
 alert(RegExp.leftContext);  //out:古道   
 /* 
  * 使用短名時有些字元是不合法的需要使用[]  
  * ["$'"] 
  * ["$+"] 
  * ["<span><span class="comment">$&</span></span>"]   
  * ["$`"] 
  */  
 alert(RegExp["<span><span class="string">$'</span></span>"]);  //out:瘦馬、夕陽西下、斷腸人在天涯!   
常用正則驗證——原連結:http://topic.csdn.net/u/20080820/14/dadb903c-8724-422e-a3bd-f2f1c4e812c6.html
[javascript]
^\d+$  //匹配非負整數(正整數 + 0)   
^[0-9]*[1-9][0-9]*$  //匹配正整數   
^((-\d+)|(0+))$  //匹配非正整數(負整數 + 0)   
^-[0-9]*[1-9][0-9]*$  //匹配負整數   
^-?\d+$    //匹配整數   
^\d+(\.\d+)?$  //匹配非負浮點數(正浮點數 + 0)   
^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$  //匹配正浮點數   
^((-\d+(\.\d+)?)|(0+(\.0+)?))$  //匹配非正浮點數(負浮點數 + 0)   
^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$  //匹配負浮點數   
^(-?\d+)(\.\d+)?$  //匹配浮點數   
^[A-Za-z]+$  //匹配由26個英文字母組成的字串   
^[A-Z]+$  //匹配由26個英文字母的大寫組成的字串   
^[a-z]+$  //匹配由26個英文字母的小寫組成的字串   
^[A-Za-z0-9]+$  //匹配由數字和26個英文字母組成的字串   
^\w+$  //匹配由數字、26個英文字母或者底線組成的字串   
^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$    //匹配email地址   
^[a-zA-z]+://匹配(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$  //匹配url   
匹配中文字元的Regex: [\u4e00-\u9fa5]   
匹配雙位元組字元(包括漢字在內):[^\x00-\xff]  
應用:計算字串的長度(一個雙位元組字元長度計2,ASCII字元計1)  
String.prototype.len=function(){return this.replace([^\x00-\xff]/g,"aa").length;}   
匹配空行的Regex:\n[\s| ]*\r   
匹配HTML標記的Regex:/<(.*)>.*<\/\1>|<(.*) \/>/   
匹配首尾空格的Regex:(^\s*)|(\s*$)  
[javascript]
/* Regex用例 
* 1、^\S+[a-z A-Z]$ 不可為空 不能有空格  只能是英文字母  
  * 2、\S{6,}         不可為空 六位以上  
  * 3、^\d+$          不能有空格 不能非數字  
  * 4、(.*)(\.jpg|\.bmp)$ 只能是jpg和bmp格式  
  * 5、^\d{4}\-\d{1,2}-\d{1,2}$ 只能是2004-10-22格式  
  * 6、^0$            至少選一項  
  * 7、^0{2,}$        至少選兩項  
  * 8、^[\s|\S]{20,}$ 不可為空 二十字以上  
  * 9、^\+?[a-z0-9](([-+.]|[_]+)?[a-z0-9]+)*@([a-z0-9]+(\.|\-))+[a-z]{2,6}$郵件  
  * 10、\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*([,;]\s*\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*)* 輸入多個地址用逗號或空格分隔郵件  
  * 11、^(\([0-9]+\))?[0-9]{7,8}$電話號碼7位或8位或前面有區號例如(022)87341628  
  * 12、^[a-z A-Z 0-9 _]+@[a-z A-Z 0-9 _]+(\.[a-z A-Z 0-9 _]+)+(\,[a-z A-Z 0-9 _]+@[a-z A-Z 0-9 _]+(\.[a-z A-Z 0-9 _]+)+)*$  
  *     只能是字母、數字、底線;必須有@和.同時格式要規範 郵件  
  * 13 ^\w+@\w+(\.\w+)+(\,\w+@\w+(\.\w+)+)*$上面運算式也可以寫成這樣子,更精練。  
    14   ^\w+((-\w+)|(\.\w+))*\@\w+((\.|-)\w+)*\.\w+$  
補充:
[javascript]
21。匹配空行的Regex:\n[\s| ]*\r  
21。匹配空行的Regex:/^\s*$/m  
  
22。匹配HTML標記的Regex:/<(.*)>.*<\/\1>|<(.*)\/>/  
22。匹配HTML標記的Regex:/<([^>]+)>[^<>]*<\/\1>|<([^>]+)\/>/  
這個實際上作用不大,因為Regex不能支援嵌套匹配,僅 .NET 的運算式引擎有這個功能。  
  
23。匹配首尾空格的Regex:(^\s*)|(\s*$)  
23。匹配首尾空格的Regex:^\s+|\s+$  
為 JavaScript 的 String 增加 trim() 函數:  
String.prototype.trim = function() {  
return this.replace(/^\s+/, '').replace(/\s+$/, '');  
}  
  
* 4、(.*)(\.jpg|\.bmp)$ 只能是jpg和bmp格式  
* 4、([^.]+)\.(jpg|bmp) 只能是jpg和bmp格式  
  
* 8、^[\s|\S]{20,}$ 不可為空 二十字以上  
* 8、^\S{20,}$ 不可為空 二十字以上  

常用正則連結:
http://www.aslibra.com/doc/regex.htm
http://www.jb51.net/article/21484.htm
http://www.blueidea.com/tech/program/2004/2273.asp
http://www.douban.com/group/topic/3402632/
http://www.blogjava.net/Vikings/archive/2006/01/06/26893.html

摘自 旦旦而學的專欄

聯繫我們

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