javaScript RegExp對象:
global——Boolean值、表示g(全局選項)是否已設置
ignoreCase——Boolean值、表示i(忽略大小寫選項)是否已設置
lastIndex——整數、代表下次匹配將會從哪個字符位置開始(隻有當使用exec()或test()函數才會填入、否則為0)
multiline——Boolean值、表示m(多行模式選項)是否已設置
source——正則表達式的源字符串形式。例如、表達式/[ba]*/的source將返回"[ba]*"。
一般不會使用global、ignoreCase、multiline和source屬性、因為一般之前就已知道瞭這些數據。
真正有用的屬性是lastIndex、它可以告訴你正則表達式在某個字符串中停止之前、查找瞭多遠。
[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
正則表達式reB查找的是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
匹配中文字符的正則表達式: [\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*$)
[javascript]
/* 正則表達式用例
* 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。匹配空行的正則表達式:\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+$/, '');
}
* 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
asp”>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
摘自 旦旦而學的專欄