好好學一遍JavaScript 筆記(七)

javaScript RegExp對象:html

    global——Boolean值、表示g(全局選項)是否已設置
    ignoreCase——Boolean值、表示i(忽略大小寫選項)是否已設置
    lastIndex——整數、表明下次匹配將會從哪一個字符位置開始(只有當使用exec()或test()函數纔會填入、不然爲0)
    multiline——Boolean值、表示m(多行模式選項)是否已設置
    source——正則表達式的源字符串形式。例如、表達式/[ba]*/的source將返回"[ba]*"。
    通常不會使用global、ignoreCase、multiline和source屬性、由於通常以前就已知道了這些數據。
    真正有用的屬性是lastIndex、它能夠告訴你正則表達式在某個字符串中中止以前、查找了多遠。java

  
  
           
  
  
  1. var sToMatch = "bbq is short for barbecue"
  2.         var reB = /b/g; 
  3.         reB.exec(sToMatch);   
  4.         alert(reB.lastIndex);    //out: 1 
  5.         reB.exec(sToMatch);   
  6.         alert(reB.lastIndex);    //out: 2  
  7.         reB.exec(sToMatch);   
  8.         alert(reB.lastIndex);    //out: 18 
  9.         reB.exec(sToMatch);   
  10.         alert(reB.lastIndex);    //out: 21   

正則表達式reB查找的是b。當它首次檢測sToMatch時、
它發如今第一個位置——也就是位置0——是b;
所以、lastIndex屬性就被設置成一、
而再次調用exec()時就從這個地方開始執行。
再次調用exec()、表達式在位置1又發現了b、
因而將lastIndex設值爲2.第三次調用時、發現b在位置1七、
因而又將lastIndex設值爲1八、如此繼續。
若是想從頭開始匹配、則能夠將lastIndex設爲0。正則表達式

 

靜態屬性:ide

  
  
           
  
  
  1. /** 
  2.       * 它們都有兩個名字:一個複雜名字和一個以美圓符號開頭的簡短名字。 
  3.       * 長名        短名     描述 
  4.       * input        $_     最後用於匹配的字符串(傳遞給exec()或test()的字符串) 
  5.       * lastMatch    $&     最後匹配的字符 
  6.       * lastParen    $+     最後匹配的分組 
  7.       * leftContext  $`     在上次匹配的前面的子串 
  8.       * multiline    $*     用於指定是否全部表達式都使用多行模式的布爾值 
  9.       * rightContext $'     在上次匹配以後的子串 
  10.       */ 
  11.      var sToMatch = "古道西風瘦馬、夕陽西下、斷腸人在天涯!";   
  12.      var reB = /(西)風/g; 
  13.      reB.test(sToMatch); 
  14.      alert(RegExp.$_);  //out:古道西風瘦馬、夕陽西下、斷腸人在天涯! 
  15.      alert(RegExp.leftContext);  //out:古道  
  16.      /* 
  17.       * 使用短名時有些字符是不合法的須要使用[]  
  18.       * ["$'"] 
  19.       * ["$+"] 
  20.       * ["$&"]   
  21.       * ["$`"] 
  22.       */ 
  23.      alert(RegExp["$'"]);  //out:瘦馬、夕陽西下、斷腸人在天涯!  

經常使用正則驗證——原連接 http://topic.csdn.net/u/20080820/14/dadb903c-8724-422e-a3bd-f2f1c4e812c6.html函數

  
  
           
  
  
  1. ^\d+$  //匹配非負整數(正整數 + 0)  
  2. ^[0-9]*[1-9][0-9]*$  //匹配正整數  
  3. ^((-\d+)|(0+))$  //匹配非正整數(負整數 + 0)  
  4. ^-[0-9]*[1-9][0-9]*$  //匹配負整數  
  5. ^-?\d+$    //匹配整數  
  6. ^\d+(\.\d+)?$  //匹配非負浮點數(正浮點數 + 0)  
  7. ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$  //匹配正浮點數  
  8. ^((-\d+(\.\d+)?)|(0+(\.0+)?))$  //匹配非正浮點數(負浮點數 + 0)  
  9. ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$  //匹配負浮點數  
  10. ^(-?\d+)(\.\d+)?$  //匹配浮點數  
  11. ^[A-Za-z]+$  //匹配由26個英文字母組成的字符串  
  12. ^[A-Z]+$  //匹配由26個英文字母的大寫組成的字符串  
  13. ^[a-z]+$  //匹配由26個英文字母的小寫組成的字符串  
  14. ^[A-Za-z0-9]+$  //匹配由數字和26個英文字母組成的字符串  
  15. ^\w+$  //匹配由數字、26個英文字母或者下劃線組成的字符串  
  16. ^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$    //匹配email地址  
  17. ^[a-zA-z]+://匹配(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$  //匹配url  
  18. 匹配中文字符的正則表達式: [\u4e00-\u9fa5]  
  19. 匹配雙字節字符(包括漢字在內):[^\x00-\xff] 
  20. 應用:計算字符串的長度(一個雙字節字符長度計2,ASCII字符計1) 
  21. String.prototype.len=function(){return this.replace([^\x00-\xff]/g,"aa").length;}  
  22. 匹配空行的正則表達式:\n[\s| ]*\r  
  23. 匹配HTML標記的正則表達式:/<(.*)>.*<\/\1>|<(.*) \/>/  
  24. 匹配首尾空格的正則表達式:(^\s*)|(\s*$)
  
  
           
  
  
  1. /* 正則表達式用例
  2. * 一、^\S+[a-z A-Z]$ 不能爲空 不能有空格  只能是英文字母 
  3.   * 二、\S{6,}         不能爲空 六位以上 
  4.   * 三、^\d+$          不能有空格 不能非數字 
  5.   * 四、(.*)(\.jpg|\.bmp)$ 只能是jpg和bmp格式 
  6.   * 五、^\d{4}\-\d{1,2}-\d{1,2}$ 只能是2004-10-22格式 
  7.   * 六、^0$            至少選一項 
  8.   * 七、^0{2,}$        至少選兩項 
  9.   * 八、^[\s|\S]{20,}$ 不能爲空 二十字以上 
  10.   * 九、^\+?[a-z0-9](([-+.]|[_]+)?[a-z0-9]+)*@([a-z0-9]+(\.|\-))+[a-z]{2,6}$郵件 
  11.   * 十、\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*([,;]\s*\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*)* 輸入多個地址用逗號或空格分隔郵件 
  12.   * 十一、^(\([0-9]+\))?[0-9]{7,8}$電話號碼7位或8位或前面有區號例如(022)87341628 
  13.   * 十二、^[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 _]+)+)*$ 
  14.   *     只能是字母、數字、下劃線;必須有@和.同時格式要規範 郵件 
  15.   * 13 ^\w+@\w+(\.\w+)+(\,\w+@\w+(\.\w+)+)*$上面表達式也能夠寫成這樣子,更精練。 
  16.     14   ^\w+((-\w+)|(\.\w+))*\@\w+((\.|-)\w+)*\.\w+$ 

補充:this

  
  
           
  
  
  1. 21。匹配空行的正則表達式:\n[\s| ]*\r 
  2. 21。匹配空行的正則表達式:/^\s*$/m 
  3.  
  4. 22。匹配HTML標記的正則表達式:/<(.*)>.*<\/\1>|<(.*)\/>/ 
  5. 22。匹配HTML標記的正則表達式:/<([^>]+)>[^<>]*<\/\1>|<([^>]+)\/>/ 
  6. 這個實際上做用不大,由於正則表達式不能支持嵌套匹配,僅 .NET 的表達式引擎有這個功能。 
  7.  
  8. 23。匹配首尾空格的正則表達式:(^\s*)|(\s*$) 
  9. 23。匹配首尾空格的正則表達式:^\s+|\s+$ 
  10. 爲 JavaScript 的 String 增長 trim() 函數: 
  11. String.prototype.trim = function() { 
  12. return this.replace(/^\s+/, '').replace(/\s+$/, ''); 
  13.  
  14. * 四、(.*)(\.jpg|\.bmp)$ 只能是jpg和bmp格式 
  15. * 四、([^.]+)\.(jpg|bmp) 只能是jpg和bmp格式 
  16.  
  17. * 八、^[\s|\S]{20,}$ 不能爲空 二十字以上 
  18. * 八、^\S{20,}$ 不能爲空 二十字以上
相關文章
相關標籤/搜索