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
- 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
正則表達式reB查找的是b。當它首次檢測sToMatch時、
它發如今第一個位置——也就是位置0——是b;
所以、lastIndex屬性就被設置成一、
而再次調用exec()時就從這個地方開始執行。
再次調用exec()、表達式在位置1又發現了b、
因而將lastIndex設值爲2.第三次調用時、發現b在位置1七、
因而又將lastIndex設值爲1八、如此繼續。
若是想從頭開始匹配、則能夠將lastIndex設爲0。正則表達式
靜態屬性:ide
- /**
- * 它們都有兩個名字:一個複雜名字和一個以美圓符號開頭的簡短名字。
- * 長名 短名 描述
- * input $_ 最後用於匹配的字符串(傳遞給exec()或test()的字符串)
- * lastMatch $& 最後匹配的字符
- * lastParen $+ 最後匹配的分組
- * leftContext $` 在上次匹配的前面的子串
- * multiline $* 用於指定是否全部表達式都使用多行模式的布爾值
- * rightContext $' 在上次匹配以後的子串
- */
- var sToMatch = "古道西風瘦馬、夕陽西下、斷腸人在天涯!";
- var reB = /(西)風/g;
- reB.test(sToMatch);
- alert(RegExp.$_); //out:古道西風瘦馬、夕陽西下、斷腸人在天涯!
- alert(RegExp.leftContext); //out:古道
- /*
- * 使用短名時有些字符是不合法的須要使用[]
- * ["$'"]
- * ["$+"]
- * ["$&"]
- * ["$`"]
- */
- alert(RegExp["$'"]); //out:瘦馬、夕陽西下、斷腸人在天涯!
經常使用正則驗證——原連接 http://topic.csdn.net/u/20080820/14/dadb903c-8724-422e-a3bd-f2f1c4e812c6.html函數
- ^\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
- 匹配中文字符的正則表達式: [\u4e00-\u9fa5]
- 匹配雙字節字符(包括漢字在內):[^\x00-\xff]
- 應用:計算字符串的長度(一個雙字節字符長度計2,ASCII字符計1)
- String.prototype.len=function(){return this.replace([^\x00-\xff]/g,"aa").length;}
- 匹配空行的正則表達式:\n[\s| ]*\r
- 匹配HTML標記的正則表達式:/<(.*)>.*<\/\1>|<(.*) \/>/
- 匹配首尾空格的正則表達式:(^\s*)|(\s*$)
/* 正則表達式用例- * 一、^\S+[a-z A-Z]$ 不能爲空 不能有空格 只能是英文字母
- * 二、\S{6,} 不能爲空 六位以上
- * 三、^\d+$ 不能有空格 不能非數字
- * 四、(.*)(\.jpg|\.bmp)$ 只能是jpg和bmp格式
- * 五、^\d{4}\-\d{1,2}-\d{1,2}$ 只能是2004-10-22格式
- * 六、^0$ 至少選一項
- * 七、^0{2,}$ 至少選兩項
- * 八、^[\s|\S]{20,}$ 不能爲空 二十字以上
- * 九、^\+?[a-z0-9](([-+.]|[_]+)?[a-z0-9]+)*@([a-z0-9]+(\.|\-))+[a-z]{2,6}$郵件
- * 十、\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*([,;]\s*\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*)* 輸入多個地址用逗號或空格分隔郵件
- * 十一、^(\([0-9]+\))?[0-9]{7,8}$電話號碼7位或8位或前面有區號例如(022)87341628
- * 十二、^[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+$
補充:this
- 21。匹配空行的正則表達式:\n[\s| ]*\r
- 21。匹配空行的正則表達式:/^\s*$/m
- 22。匹配HTML標記的正則表達式:/<(.*)>.*<\/\1>|<(.*)\/>/
- 22。匹配HTML標記的正則表達式:/<([^>]+)>[^<>]*<\/\1>|<([^>]+)\/>/
- 這個實際上做用不大,由於正則表達式不能支持嵌套匹配,僅 .NET 的表達式引擎有這個功能。
- 23。匹配首尾空格的正則表達式:(^\s*)|(\s*$)
- 23。匹配首尾空格的正則表達式:^\s+|\s+$
- 爲 JavaScript 的 String 增長 trim() 函數:
- String.prototype.trim = function() {
- return this.replace(/^\s+/, '').replace(/\s+$/, '');
- }
- * 四、(.*)(\.jpg|\.bmp)$ 只能是jpg和bmp格式
- * 四、([^.]+)\.(jpg|bmp) 只能是jpg和bmp格式
- * 八、^[\s|\S]{20,}$ 不能爲空 二十字以上
- * 八、^\S{20,}$ 不能爲空 二十字以上