驗證密碼強(qiáng)度
必須同時包含大小寫字母、數(shù)字炉峰、特殊字符复颈、8-16位。
方法一:var reg=/^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[\W_]).{8,16}$/;
方法二:var reg=/^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*([^\w]|_)).{8,16}$/;
alert(reg.test["0A#1234a"]);
可以包含大小寫字母亲澡、數(shù)字钦扭、特殊字符,8-16位床绪。
var reg=/^[\w\W]{8,16}$/;
常用驗證
驗證數(shù)字:^[0-9]*$
驗證n位的數(shù)字:^\d{n}$
驗證至少n位數(shù)字:^\d{n,}$
驗證m-n位的數(shù)字:^\d{m,n}$
驗證零和非零開頭的數(shù)字:^(0|[1-9][0-9]*)$
驗證有兩位小數(shù)的正實數(shù):^[0-9]+(.[0-9]{2})?$
驗證有1-3位小數(shù)的正實數(shù):^[0-9]+(.[0-9]{1,3})?$
驗證非零的正整數(shù):^\+?[1-9][0-9]*$
驗證非零的負(fù)整數(shù):^\-[1-9][0-9]*$
驗證非負(fù)整數(shù)(正整數(shù) + 0)?? ^\d+$
驗證非正整數(shù)(負(fù)整數(shù) + 0)?? ^((-\d+)|(0+))$
驗證長度為3的字符:^.{3}$
驗證由26個英文字母組成的字符串:^[A-Za-z]+$
驗證由26個大寫英文字母組成的字符串:^[A-Z]+$
驗證由26個小寫英文字母組成的字符串:^[a-z]+$
驗證由數(shù)字和26個英文字母組成的字符串:^[A-Za-z0-9]+$
驗證由數(shù)字客情、26個英文字母或者下劃線組成的字符串:^\w+$
驗證用戶密碼:^[a-zA-Z]\w{5,17}$ 正確格式為:以字母開頭,長度在6-18之間癞己,只能包含字符膀斋、數(shù)字和下劃線。
驗證是否含有 ^%&',;=?$\" 等字符:[^%&',;=?$\x22]+
驗證漢字:^[\一-\龥],{0,}$
驗證Email地址:^\w+[-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$
驗證InternetURL:^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$ 痹雅;^[a-zA-z]+://(w+(-w+)*)(.(w+(-w+)*))*(?S*)?$
驗證電話號碼:^(\d3,4\d3,4|\d{3,4}-)?\d{7,8}$:--正確格式為:XXXX-XXXXXXX仰担,XXXX-XXXXXXXX,XXX-XXXXXXX绩社,XXX-XXXXXXXX摔蓝,XXXXXXX,XXXXXXXX愉耙。
驗證身份證號(15位或18位數(shù)字):^\d{15}|\d{}18$
驗證一年的12個月:^(0?[1-9]|1[0-2])$ 正確格式為:“01”-“09”和“1”“12”
驗證一個月的31天:^((0?[1-9])|((1|2)[0-9])|30|31)$ 正確格式為:01想幻、09和1谆趾、31。
整數(shù):^-?\d+$
非負(fù)浮點數(shù)(正浮點數(shù) + 0):^\d+(\.\d+)?$
正浮點數(shù) ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$
非正浮點數(shù)(負(fù)浮點數(shù) + 0) ^((-\d+(\.\d+)?)|(0+(\.0+)?))$
負(fù)浮點數(shù)?? ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$
浮點數(shù)?? ^(-?\d+)(\.\d+)?$
其他
1. /A-Z/ 驗證至少一個大寫字母
2. /a-z/ 驗證至少一個小寫字母
3. /\d/ 驗證至少一個數(shù)字
4. /[^\w] 驗證至少一個非單詞字符, 注意: ?正則將 _ (下劃線)計算為一個字符
補(bǔ)充: 如果需要把_(下劃線)包含進(jìn)去,正則就應(yīng)該這樣寫:?/[^\w]|_/
擴(kuò)充
1.Flex正則表達(dá)式規(guī)則
1.1普通字符
字母、數(shù)字麻惶、漢字、下劃線囱修、以及后邊章節(jié)中沒有特殊定義的標(biāo)點符號想诅,都是"普通字符"。表達(dá)式中的普通字符锡垄,在匹配一個字符串的時候沦零,匹配與之相同的一個字符。
舉例1:表達(dá)式"c"货岭,在匹配字符串"abcde"時路操,匹配結(jié)果是:成功疾渴;匹配到的內(nèi)容是:"c";匹配到的位置是:開始于2屯仗,結(jié)束于3搞坝。(注:下標(biāo)從0開始還是從1開始,因當(dāng)前編程語言的不同而可能不同)
舉例2:表達(dá)式"bcd"魁袜,在匹配字符串"abcde"時桩撮,匹配結(jié)果是:成功;匹配到的內(nèi)容是:"bcd"峰弹;匹配到的位置是:開始于1店量,結(jié)束于4。
1.2簡單的轉(zhuǎn)義字符
Flex正則表達(dá)式中一些不便書寫的字符鞠呈,采用在前面加""的方法融师。這些字符其實我們都已經(jīng)熟知了。
表達(dá)式可匹配
\r,\n
代表回車和換行符
\t
制表符
\\
代表""本身
◆還有其他一些在后邊章節(jié)中有特殊用處的標(biāo)點符號蚁吝,在前面加""后诬滩,就代表該符號本身。比如:^,$都有特殊意義灭将,如果要想匹配字符串中"^"和"$"字符疼鸟,則表達(dá)式就需要寫成"\^"和"\$"。
表達(dá)式可匹配
\^
匹配^符號本身
\$
匹配$符號本身
\.
匹配小數(shù)點(.)本身
這些轉(zhuǎn)義字符的匹配方法與"普通字符"是類似的庙曙。也是匹配與之相同的一個字符空镜。
舉例1:表達(dá)式"\$d",在匹配字符串"abc$de"時捌朴,匹配結(jié)果是:成功吴攒;匹配到的內(nèi)容是:"$d";匹配到的位置是:開始于3砂蔽,結(jié)束于5洼怔。
1.3能夠與'多種字符'匹配的表達(dá)式
Flex正則表達(dá)式中的一些表示方法,可以匹配'多種字符'其中的任意一個字符左驾。比如镣隶,表達(dá)式"\d"可以匹配任意一個數(shù)字。雖然可以匹配其中任意字符诡右,但是只能是一個安岂,不是多個。這就好比玩撲克牌時候帆吻,大小王可以代替任意一張牌域那,但是只能代替一張牌。
表達(dá)式可匹配
\d
任意一個數(shù)字猜煮,0~9中的任意一個
\w
任意一個字母或數(shù)字或下劃線次员,也就是A~Z,a~z,0~9,_中任意一個
\s
包括空格败许、制表符、換頁符等空白字符的其中任意一個
.
小數(shù)點可以匹配除了換行符(\n)以外的任意一個字符
舉例1:表達(dá)式"\d\d"淑蔚,在匹配"abc123"時市殷,匹配的結(jié)果是:成功;匹配到的內(nèi)容是:"12"束倍;匹配到的位置是:開始于3被丧,結(jié)束于5盟戏。
舉例2:表達(dá)式"a.\d"绪妹,在匹配"aaa100"時,匹配的結(jié)果是:成功柿究;匹配到的內(nèi)容是:"aa1"邮旷;匹配到的位置是:開始于1,結(jié)束于4蝇摸。
1.4自定義能夠匹配'多種字符'的表達(dá)式
Flex正則表達(dá)式中使用方括號[]包含一系列字符婶肩,能夠匹配其中任意一個字符。用[^]包含一系列字符貌夕,則能夠匹配其中字符之外的任意一個字符律歼。同樣的道理,雖然可以匹配其中任意一個啡专,但是只能是一個险毁,不是多個。
表達(dá)式可匹配
[ab5@]
匹配"a"或"b"或"5"或"@"
[^abc]
匹配"a","b","c"之外的任意一個字符
[f-k]
匹配"f"~"k"之間的任意一個字母
[^A-F0-3]
匹配"A"~"F","0"~"3"之外的任意一個字符
舉例1:表達(dá)式"[bcd][bcd]"匹配"abc123"時们童,匹配的結(jié)果是:成功畔况;匹配到的內(nèi)容是:"bc";匹配到的位置是:開始于1慧库,結(jié)束于3跷跪。
舉例2:表達(dá)式"[^abc]"匹配"abc123"時,匹配的結(jié)果是:成功齐板;匹配到的內(nèi)容是:"1"吵瞻;匹配到的位置是:開始于3,結(jié)束于4甘磨。
http://hi.baidu.com/fengpingfan123/blog/item/9a0ffdef3be51b2fadafd5cc.html
談?wù)務(wù)齽t表達(dá)式听皿,AS3.0中引進(jìn)了正則表達(dá)式。正則表達(dá)式是用于驗證文本值是否符合特定模式宽档。
正則表達(dá)式有四個部分尉姨。1元子符。2元序列吗冤。3標(biāo)志又厉。4數(shù)量表達(dá)符九府。
可以這樣看 pattern RegExp= /匹配字符串元字符元序列/標(biāo)志當(dāng)然順序可能不完全是這樣.別把他想的太復(fù)雜其實他就是個組合。
現(xiàn)在我們來看看元字符: ^ $ \ . * + ? ( ) [ ] { } |
前面說的是轉(zhuǎn)義字符串的使用
元子符
1.^的用法:匹配字符串的開頭
var pattern:RegExp=/^小蟲/;
var str:String="小蟲是好人";
trace(str, " is valid:", pattern.test(str));小蟲是好人 is valid: true
2.$的用法:匹配字符串的結(jié)尾
var pattern:RegExp=/lizhen$/;
var str:String="My name is lizhen";
trace(str, " is valid:", pattern.test(str));小蟲是好人 is valid: true
仔細(xì)看一下兩個符號在匹配字符串中的位置覆致,注意:如果同時使用^符號和$符號侄旬,將進(jìn)行精確匹配。
3.\的用法:匹配字符串的結(jié)尾
如果匹配字符串中包含有"/"比如 1/2 的時候煌妈,使用如下定義
var pattern:RegExp = /1\/2/;
var str:String="1/2是多少儡羔?";
trace(str, " is valid:", pattern.test(str));1/2是多少? is valid: true
如果匹配字符串中包含有""比如 "lizhen" 的時候璧诵,使用如下定義
var pattern:RegExp=/"lizhen"/;
var str:String="My name is "lizhen"";
trace(str, " is valid:", pattern.test(str));My name is "lizhen" is valid: true
4.*的用法:匹配0個或多個前面的字符.
var pattern:RegExp=/我的*/;
var str:String="我的我的我的";或者var str:String="我的"
trace(str, " is valid:", pattern.test(str));我的我的... is valid: true
5.+的用法:匹配至少一個前面的字符
var pattern:RegExp=/我的+/;
var str:String="我的ID是...";或者var str:String="我的"
trace(str, " is valid:", pattern.test(str));我的ID是... is valid: true
注意+和*的區(qū)別汰蜘。如果var str:String="我的"那就會顯示false
6.?的用法:匹配0個或1個前面的字符
var pattern:RegExp=/天?/;
var str:String="一天快樂";或者var str:String="天天快樂";
trace(str, " is valid:", pattern.test(str));一天快樂 is valid: true
7..的用法:匹配任意單個字符
var pattern:RegExp=/天./;
var str:String="一天快樂";或者var str:String="天天快樂";
trace(str, " is valid:", pattern.test(str));一天快樂 is valid: true
8.[ ]的用法:匹配某一個范圍而不局限于具體的單個字符
var pattern:RegExp=/[a-z]/
var str:String="a"
trace(str, " is valid:", pattern.test(str));a is valid: true
9.( )的用法:這個就相當(dāng)于是個集合。
var pattern:RegExp=/([a-z][A-Z][0-9])+/ 比如說這個就是定義了一個四個字符的字符串第一個字符是a到z之間的字符第二個是A到Z之間的字符第三個是0-9之間的字符之宿,第四個重復(fù)前面的數(shù)字族操。
var str:String="aD77aaaaaaaaaaaaaaaa"
trace(str, " is valid:", pattern.test(str));aD77aaaaaaaaaaaaaaaa is valid: true
10.|的用法:匹配左邊或者右邊的字符。
var pattern:RegExp=/小蟲|lizhen/
var str:String="小蟲是好人"
trace(str, " is valid:", pattern.test(str));小蟲是好人 is valid: true
元序列
元序列是在正則表達(dá)式模式中具有特殊含義的字符序列
{n} {n,} {n,m} \b \B \d \D \f \n \r \s \S \t \unnnn \v \w \w \W \xnn
1.{n}的用法:匹配恰好n個(n為非負(fù)整數(shù))前面的字符比被。
var pattern:RegExp=/(小蟲){2}/ 對象中連續(xù)出現(xiàn)2次小蟲.注意下()色难,如果用var pattern:RegExp=/小蟲{2}/ 那么就是var str:String="小蟲蟲"
var str:String="小蟲小蟲"
trace(str, " is valid:", pattern.test(str));小蟲小蟲 is valid: true.
2.{n,}的用法:匹配恰好n個(n為非負(fù)整數(shù))或更多個前面的字符。
3.{n,m}的用法:匹配至少n個等缀,至多m個前面的字符枷莉。
4.\b的用法:匹配單詞字符和非單詞字符之間的位置只能放在開頭和結(jié)尾。
NN的尺迂,他不支持中文.用中文還是用^.
var pattern:RegExp=/\b小蟲/
var pattern:RegExp=/.mp3\b/
var str:String="小蟲.mp3"可以判斷是否是mp3格式笤妙。
trace(str," is valid:", pattern.test(str));小蟲.mp3 is valid: true
5.\B的用法:匹配對象必須位于目標(biāo)字符串的開頭和結(jié)尾兩個邊界之內(nèi),
即匹配對象既不能作為目標(biāo)字符串的開頭枪狂,也不能作為目標(biāo)字符串的結(jié)尾和\b相反危喉。
var pattern:RegExp=/\B是/
var str:String="我是蟲子"
trace(str," is valid:", pattern.test(str));我是蟲子 is valid: true
6.\d的用法:用于匹配從0到9的數(shù)字;
var pattern:RegExp=/\b\d/ 開頭的第一字符必須為數(shù)字
var str:String="900/元"
trace(str," is valid:", pattern.test(str)); 900/元 is valid: true
7.\D的用法:匹配除數(shù)字以外的任何字符
var pattern:RegExp=/\b\D/ 開頭的第一字符必須不為數(shù)字
var str:String="a900/元"
trace(str," is valid:", pattern.test(str)); a900/元 is valid: true
8.\f的用法:匹配換頁符DOS操作時代的概念
9.\n的用法:匹配換行符
var pattern:RegExp=/\n/
var str:String="歡迎來到蟲子的空間!\n"
trace(str," is valid:", pattern.test(str));
10.\r的用法:匹配回車符
var pattern:RegExp=/\r/
var str:String="歡迎來到蟲子的空間!\r"
trace(str," is valid:", pattern.test(str));
11.\s的用法:匹配任何空白字符(空格州疾、制表符辜限、換行符或回車符)
var pattern:RegExp=/\s/
var str:String="歡迎來到蟲子的 空間!"
trace(str," is valid:", pattern.test(str)); 歡迎來到蟲子的 空間! is valid: true
12.\S的用法:匹配除空白字符以外的任何字符
var pattern:RegExp=/\S/
var str:String="歡迎來到蟲子的空間!"
trace(str," is valid:", pattern.test(str)); 歡迎來到蟲子的空間! is valid: true
13.\t的用法:匹配制表符DOS操作時代的概念
14.\unnnn用法:匹配字符代碼由十六進(jìn)制數(shù)字 nnnn 指定的 Unicode 字符。
例如严蓖,\u263a 是一個笑臉字符
var pattern:RegExp=/\u263a/
var str:String="歡迎來到蟲子的空間!\u263a"
trace(str," is valid:", pattern.test(str)); 歡迎來到蟲子的空間!? is valid: true
15.\v 用法:匹配垂直換頁符DOS操作時代的概念
16.\w用法:匹配單詞字符(A-Z薄嫡、a-z、0-9 或 _)颗胡。
請注意毫深,\w不匹配非英文字符,如é毒姨、? 或 ?哑蔫。他和[]是有區(qū)別的。
var pattern:RegExp=/^\w/
var str:String="a蟲子"
var str:String="0蟲子"
var str:String="A蟲子"
var str:String="_蟲子"
trace(str," is valid:", pattern.test(str));_蟲子 is valid: true
17.\W用法:匹配除單詞字符以外的任何字符。
var pattern:RegExp=/^\W/
var str:String="蟲子"
trace(str," is valid:", pattern.test(str));蟲子 is valid: true
18.\xnn用法:匹配具有指定 ASCII 值(由十六進(jìn)制數(shù)字 nn 定義)的字符闸迷。
var pattern:RegExp=/^\x41/;"A"
var str:String="ABCD";
trace(str," is valid:", pattern.test(str));ABCD is valid: true
標(biāo)志:
標(biāo)志可以作為正則表達(dá)式對象屬性進(jìn)行訪問嵌纲。
正則表達(dá)式有五個標(biāo)志:g i m s x
1.g的用法:如果不指定g,那么在查找的時候只會返回一個。
如:
var str:String = "she sells seashells by the seashore.";
var pattern:RegExp = /sh\w*/;
trace(str.match(pattern)) 輸出:she
指定g后:
var str:String = "she sells seashells by the seashore.";
var pattern:RegExp = /sh\w*/g;
trace(str.match(pattern)) 輸出:she,shells,shore
2.i的用法:默認(rèn)情況下腥沽,正則表達(dá)式匹配區(qū)分大小寫逮走。如果設(shè)置 i (ignoreCase) 標(biāo)志,將忽略區(qū)分大小寫今阳。
var str:String = "She sells seaShells by the seaShore.";
var pattern:RegExp = /sh\w*/gi;
trace(str.match(pattern)) 輸出:She,Shells,Shore
3.m的用法:匹配"行"的開頭和結(jié)尾.注意這里的行只有 \n 字符表示行的結(jié)束师溅,其余的都不行。包括\r盾舌。比如:
var str:String = "She sells seaShells by the seaShore.\n";
str+="She's your mother"
var pattern:RegExp = /^sh\w*/gim;
trace(str.match(pattern)) 輸出:She,She
也可以在結(jié)尾使用.比如:
var str:String = "She sells seaShells by the seaShore.\n";
str+="She's your mother.\n"
var pattern:RegExp = /\n\$\w*/gim;
trace("====="+str.match(pattern)) 輸出:=====
4.s的用法:用點來匹配換行符
var str:String = "<p>Test\n";
str += "Multiline</p>";
var re:RegExp = /<p>.*?<\/p>/s;
trace(str.match(re));
5.x的用法:在正則表達(dá)式中使用 x (extended) 標(biāo)志時墓臭,則會忽略在模式中鍵入的所有空格。
var str:String = "lizhen";
var re:RegExp = /li zhen/x
trace(str.match(re));輸出:lizhen
數(shù)量表示符
使用數(shù)量表示符指定字符或序列在模式中的重復(fù)次數(shù)矿筝,如下所示:
數(shù)量表示符元字符
描述
*(星號)
匹配前面重復(fù)零次或多次的項目起便。
+(加號)
匹配前面重復(fù)一次或多次的項目棚贾。
?(問號)
匹配前面重復(fù)零次或一次的項目窖维。
{n}
{n,}
和
{n,n}
指定前一項目的數(shù)值數(shù)量或數(shù)量范圍:
/A{27}/ 匹配重復(fù) 27 次的字符 A。
/A{3,}/ 匹配重復(fù) 3 次或更多次的字符 A妙痹。
/A{3,5}/ 匹配重復(fù) 3 到 5 次的字符 A铸史。
您可以將數(shù)量表示符應(yīng)用到單個字符、字符類或組:
/a+/ 匹配重復(fù)一次或多次的字符 a怯伊。
/\d+/ 匹配一個或多個數(shù)字琳轿。
/[abc]+/ 匹配重復(fù)的一個或多個字符,這些字符可能是 a耿芹、b 或 c 中的某個崭篡。
/(very, )*/ 匹配重復(fù)零次或多次的后跟逗號和空格的單詞 very。
您可以在應(yīng)用數(shù)量表示符的括號組內(nèi)使用數(shù)量表示符吧秕。例如琉闪,下面的數(shù)量表示符匹配諸如 word 和 word-word-word 的字符串:
/\w+(-\w+)*/
默認(rèn)情況下,正則表達(dá)式執(zhí)行所謂的“無限匹配”砸彬。正則表達(dá)式中的任何子模式(如 .*)都會嘗試在字符串中匹配盡可能多的字符颠毙,然后再執(zhí)行正則表達(dá)式的下一部分。例如砂碉,使用以下正則表達(dá)式和字符串:
var pattern:RegExp = /<p>.*<\/p>/;
str:String = "<p>Paragraph 1</p> <p>Paragraph 2</p>";
正則表達(dá)式匹配整個字符串:
<p>Paragraph 1</p> <p>Paragraph 2</p>
但是蛀蜜,假如您只想匹配一個 <p>...</p> 組。則可以通過以下操作實現(xiàn):
<p>Paragraph 1</p>
在所有數(shù)量表示符后添加問號 (?) 以將其更改為所謂的“惰性數(shù)量表示符”增蹭。例如滴某,下面的正則表達(dá)式使用惰性數(shù)量表示符 *? 匹配 <p> 后跟數(shù)量最少(惰性)的字符,再跟 </p> 的模式:
/<p>.*?<\/p>/
有關(guān)數(shù)量表示符,請牢記以下幾點:
數(shù)量表示符 {0} 和 {0,0} 不會從匹配中排除項目霎奢。
不要結(jié)合使用多個數(shù)量表示符偏瓤,例如 /abc+*/ 中。
在除非設(shè)置 s (dotall) 標(biāo)志椰憋,否則不會跨越多行厅克,即使后跟 * 數(shù)量表示符。例如橙依,請考慮使用以下代碼:
var str:String = "<p>Test\n";
str += "Multiline</p>";
var re:RegExp = /<p>.*<\/p>/;
trace(str.match(re)); // null;
re = /<p>.*<\/p>/s;
trace(str.match(re));
// output: <p>Test
// Multiline</p>
有
常用的正則表達(dá)式語句
^\d+$ //匹配非負(fù)整數(shù)(正整數(shù) + 0)
^[0-9]*[1-9][0-9]*$ //匹配正整數(shù)
^((-\d+)|(0+))$ //匹配非正整數(shù)(負(fù)整數(shù) + 0)
^-[0-9]*[1-9][0-9]*$ //匹配負(fù)整數(shù)
^-?\d+$ //匹配整數(shù)
^\d+(\.\d+)?$ //匹配非負(fù)浮點數(shù)(正浮點數(shù) + 0)
^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$ //匹配正浮點數(shù)
^((-\d+(\.\d+)?)|(0+(\.0+)?))$ //匹配非正浮點數(shù)(負(fù)浮點數(shù) + 0)
^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$ //匹配負(fù)浮點數(shù)
^(-?\d+)(\.\d+)?$ //匹配浮點數(shù)
^[A-Za-z]+$ //匹配由26個英文字母組成的字符串
^[A-Z]+$ //匹配由26個英文字母的大寫組成的字符串
^[a-z]+$ //匹配由26個英文字母的小寫組成的字符串
^[A-Za-z0-9]+$ //匹配由數(shù)字和26個英文字母組成的字符串
^\w+$ //匹配由數(shù)字证舟、26個英文字母或者下劃線組成的字符串
^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$ //匹配email地址
^[a-zA-z]+://匹配(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$ //匹配url
匹配中文字符的正則表達(dá)式: [\u4e00-\u9fa5]
匹配雙字節(jié)字符(包括漢字在內(nèi)):[^\x00-\xff]
匹配空行的正則表達(dá)式:\n[\s| ]*\r
匹配HTML標(biāo)記的正則表達(dá)式:/<(.*)>.*<\/>|<(.*) \/>/
匹配首尾空格的正則表達(dá)式:(^\s*)|(\s*$)
匹配Email地址的正則表達(dá)式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
匹配網(wǎng)址URL的正則表達(dá)式:^[a-zA-z]+://(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$
匹配帳號是否合法(字母開頭,允許5-16字節(jié)窗骑,允許字母數(shù)字下劃線):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
匹配國內(nèi)電話號碼:(\d{3}-|\d{4}-)?(\d{8}|\d{7})?
匹配騰訊QQ號:^[1-9]*[1-9][0-9]*$
下表是元字符及其在正則表達(dá)式上下文中的行為的一個完整列表:
\ 將下一個字符標(biāo)記為一個特殊字符女责、或一個原義字符、或一個后向引用创译、或一個八進(jìn)制轉(zhuǎn)義符抵知。
^ 匹配輸入字符串的開始位置。如果設(shè)置了 RegExp 對象的Multiline 屬性软族,^ 也匹配 ’\n’ 或 ’\r’ 之后的位置刷喜。
$ 匹配輸入字符串的結(jié)束位置。如果設(shè)置了 RegExp 對象的Multiline 屬性立砸,$ 也匹配 ’\n’ 或 ’\r’ 之前的位置掖疮。
* 匹配前面的子表達(dá)式零次或多次。
+ 匹配前面的子表達(dá)式一次或多次颗祝。+ 等價于 {1,}浊闪。
? 匹配前面的子表達(dá)式零次或一次。? 等價于 {0,1}螺戳。
{n} n 是一個非負(fù)整數(shù)搁宾,匹配確定的n 次。
{n,} n 是一個非負(fù)整數(shù)倔幼,至少匹配n 次盖腿。
{n,m} m 和 n 均為非負(fù)整數(shù),其中n <= m凤藏。最少匹配 n 次且最多匹配 m 次奸忽。在逗號和兩個數(shù)之間不能有空格。
? 當(dāng)該字符緊跟在任何一個其他限制符 (*, +, ?, {n}, {n,}, {n,m}) 后面時揖庄,匹配模式是非貪婪的栗菜。非貪婪模式盡可能少的匹配所搜索的字符串,而默認(rèn)的貪婪模式則盡可能多的匹配所搜索的字符串蹄梢。
. 匹配除 "\n" 之外的任何單個字符疙筹。要匹配包括 ’\n’ 在內(nèi)的任何字符富俄,請使用象 ’[.\n]’ 的模式。
(pattern) 匹配pattern 并獲取這一匹配而咆。
(?:pattern) 匹配pattern 但不獲取匹配結(jié)果霍比,也就是說這是一個非獲取匹配,不進(jìn)行存儲供以后使用暴备。
(?=pattern) 正向預(yù)查悠瞬,在任何匹配 pattern 的字符串開始處匹配查找字符串。這是一個非獲取匹配涯捻,也就是說浅妆,該匹配不需要獲取供以后使用。
(?!pattern) 負(fù)向預(yù)查障癌,與(?=pattern)作用相反
x|y 匹配 x 或 y凌外。
[xyz] 字符集合。
[^xyz] 負(fù)值字符集合涛浙。
[a-z] 字符范圍康辑,匹配指定范圍內(nèi)的任意字符。
[^a-z] 負(fù)值字符范圍轿亮,匹配任何不在指定范圍內(nèi)的任意字符疮薇。
\b 匹配一個單詞邊界,也就是指單詞和空格間的位置哀托。
\B 匹配非單詞邊界惦辛。
\cx 匹配由x指明的控制字符劳秋。
\d 匹配一個數(shù)字字符仓手。等價于 [0-9]。
\D 匹配一個非數(shù)字字符玻淑。等價于 [^0-9]嗽冒。
\f 匹配一個換頁符。等價于 \x0c 和 \cL补履。
\n 匹配一個換行符添坊。等價于 \x0a 和 \cJ。
\r 匹配一個回車符箫锤。等價于 \x0d 和 \cM贬蛙。
\s 匹配任何空白字符,包括空格谚攒、制表符阳准、換頁符等等。等價于[ \f\n\r\t\v]馏臭。
\S 匹配任何非空白字符野蝇。等價于 [^ \f\n\r\t\v]。
\t 匹配一個制表符。等價于 \x09 和 \cI绕沈。
\v 匹配一個垂直制表符锐想。等價于 \x0b 和 \cK。
\w 匹配包括下劃線的任何單詞字符乍狐。等價于’[A-Za-z0-9_]’赠摇。
\W 匹配任何非單詞字符。等價于 ’[^A-Za-z0-9_]’浅蚪。
\xn 匹配 n蝉稳,其中 n 為十六進(jìn)制轉(zhuǎn)義值。十六進(jìn)制轉(zhuǎn)義值必須為確定的兩個數(shù)字長掘鄙。
\num 匹配 num耘戚,其中num是一個正整數(shù)。對所獲取的匹配的引用操漠。
\n 標(biāo)識一個八進(jìn)制轉(zhuǎn)義值或一個后向引用收津。如果 \n 之前至少 n 個獲取的子表達(dá)式,則 n 為后向引用浊伙。否則撞秋,如果 n 為八進(jìn)制數(shù)字 (0-7),則 n 為一個八進(jìn)制轉(zhuǎn)義值嚣鄙。
\nm 標(biāo)識一個八進(jìn)制轉(zhuǎn)義值或一個后向引用吻贿。如果 \nm 之前至少有is preceded by at least nm 個獲取得子表達(dá)式,則 nm 為后向引用哑子。如果 \nm 之前至少有 n 個獲取舅列,則 n 為一個后跟文字 m 的后向引用。如果前面的條件都不滿足卧蜓,若 n 和 m 均為八進(jìn)制數(shù)字 (0-7)帐要,則 \nm 將匹配八進(jìn)制轉(zhuǎn)義值 nm。
\nml 如果 n 為八進(jìn)制數(shù)字 (0-3)弥奸,且 m 和 l 均為八進(jìn)制數(shù)字 (0-7)榨惠,則匹配八