亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

超全的js正則表達式整理筆記

 更新時間:2015年12月01日 11:59:45   作者:zzq58157383  
這篇文章為大家分享了一篇超全的javascript正則表達式整理筆記,感興趣的小伙伴們可以參考一下

var reCat = new RegExp("cat", "gi"); //RegExp構(gòu)造函數(shù)可以帶一個或兩個參數(shù),第一個參數(shù)描述需要進行匹配的模式字符串,第二個參數(shù)指定了額外的處理命令 
var reCat = /cat/gi; //使用Perl風(fēng)格的語法 
 
 i:執(zhí)行對大小寫不敏感的匹配 
 g:執(zhí)行全局匹配(查找所有匹配而非在找到第一個匹配后停止) 
 m:執(zhí)行多行匹配 


元字符 

元字符是表達式語法的一部分,在正則表達式中用到的所有元字符有:{ [ ( \ ^ $ | ) ] } ? * + - 
如匹配一個問號:var reQMark = /\?/; 或 var reQMark = new RegExp("\\?"); //注意這里是兩個反斜杠,雙重轉(zhuǎn)義  

\xxx 查找以八進制數(shù) xxx 規(guī)定的字符,如:/\142/為字符b 
\xdd 查找以十六進制數(shù) dd 規(guī)定的字符,如:/\x62/為字符b 
\uxxxx 查找以十六進制數(shù) xxxx 規(guī)定的 Unicode 字符,如:/\u0062/為字符b 
\r 查找回車符 
\n 查找換行符 
\f 查找換頁符 
\t 查找制表符 
\v 查找垂直制表符 
\a 查找alert字符 
\e 查找escape字符 
\cX 查找與X相對應(yīng)的控制字符 
\0 查找 NULL 字符 
 
. 查找單個字符,除了換行和行結(jié)束符,等同于[^\n\r] 
\w 查找單詞字符,等同于[a-zA-Z_0-9] 
\W 查找非單詞字符,等同于[^a-zA-Z_0-9] 
\d 查找數(shù)字,等同于[0-9] 
\D 查找非數(shù)字字符,等同于[^0-9] 
\s 查找空白字符,等同于[ \t\n\x0B\f\r],\x0B為垂直tab和\t一樣 
\S 查找非空白字符,等同于[^ \t\n\x0B\f\r] 

方括號 

[abc] 查找方括號之間的任何字符 
[^abc] 查找任何不在方括號之間的字符 
[0-9] 查找任何從 0 至 9 的數(shù)字 
[a-z] 查找任何從小寫 a 到小寫 z 的字符 
[A-Z] 查找任何從大寫 A 到大寫 Z 的字符 
[A-z] 查找任何從大寫 A 到小寫 z 的字符 
[adgk] 查找給定集合內(nèi)的任何字符 
[^adgk] 查找給定集合外的任何字符 

量詞 
? 匹配任何包含零個或一個的字符串,如:ba?d匹配bd、bad 
+ 匹配任何包含至少一個的字符串,如:ba+d匹配bad、baad 
* 匹配任何包含零個或多個的字符串,如:ba*d匹配bd、bad、baad 
{n} 匹配包含恰好出現(xiàn)n次的序列的字符串,如:ba{1}d匹配bad 
{n,m} 匹配包含至少n次但不超過m次 的序列的字符串,如:ba{0,1}d匹配bd、bad 
{n,} 匹配包含至少出現(xiàn)n次的序列的字符串,如:ba{0,}匹配bd、bad、baad、baaad   
貪婪量詞:先看整個的字符串是否匹配,如果發(fā)現(xiàn)沒有匹配,去年該字符串中的最后一個字符并再次嘗試,如:?、+、*、{n}、{n, m}、{n, },默認就為貪婪量詞 
惰性量詞:先看字符串中的第一個字母是否匹配,如果單獨這一個字符還不夠,就讀入下一個字符,組成兩個字符的字符串,與貪婪量詞的工作方式恰好相反,如:??、+?、*?、{n}?、{n, m}?、{n, }? 
支配量詞:只嘗試匹配整個字符串,如果整個字符串不能產(chǎn)生匹配,不做進一步嘗試,如:?+、++、*+、{n}+、{n, m}+、{n, }+  

var sToMatch = "abbbaabbbaaabbb1234"; 
var re1 = /.*bbb/g; //匹配結(jié)果為"abbbaabbbaaabbb" 
var re2 = /.*?bbb/g; //只有惰性量詞才能匹配成功,匹配結(jié)果為"abbb","aabbb","aaabbb" 
var re3 = /.*+bbb/g; //匹配不了,直接報錯 

復(fù)雜模式之分組:通過一系列括號包圍一系列字符、字符類以及量詞來使用的 
/(dog){2}/  匹配"dogdog" 
/([bd]ad?)*/  匹配空, "ba", "da", "bad", "dad" 
/(mom( and dad)?)/  匹配"mom", "mom and dad" 
/^\s*(.*?)\s+$/  匹配首尾的空白字符,也可以用/^\s+|\s+$/g 
復(fù)雜模式之反向引用:也叫捕獲性分組,按照從左到右遇到的左括號字符的順序進行創(chuàng)建和編號的,例如表達式(A?(B?(C?)))將產(chǎn)生編號從1-3的三個反向引用:(A?(B?(C?)))、(B?(C?))、(C?) 
反向引用有幾種不同的使用方法: 
首先,使用正則表達式對象的test()、match()或search()方法后,反向引用的值可以從RegExp構(gòu)造函數(shù)中獲得,如: 

var sToMatch = "#123456789"; 
var reNumbers = /#(\d+)/; 
reNumbers.test(sToMatch); 
alert(RegExp.$1); //"123456789",$1保存了第一個反向引用,依次可以用$2,$3... 

然后,可以直接在定義分組的表達式中包含反向引用,通過使用特殊轉(zhuǎn)義序列如\1、\2等實現(xiàn) 

var sToMatch = "dogdog"; 
var reDogdog = /(dog)\1/; //等同于/dogdog/ 
alert(reDogdog.test(sToMatch)); //true 

第三,反向引用可以用在String對象的replace()方法中,通過使用特殊字符序列如$1、$2等實現(xiàn) 

var sToChange = "1234 5678"; 
var reMatch = /(\d{4}) (\d{4})/; 
alert(sToChange.replace(reMatch, "$2 $1")); //"5678 1234" 

復(fù)雜模式之候選:使用管道符(|)放在兩個單獨的模式之間 

var reBadWords = /badword | anotherbadword/gi; 
var sUserInput = "This is a String using badword1 and badword2."; 
var sFinalText = sUserInput.replace(reBadWords, function(sMatch){ 
 return sMatch.replace(/./g, "*"); //用星號替換敏感詞中的每一個字母 
}); 

復(fù)雜模式之非捕獲性分組:相比捕獲性分組,不會創(chuàng)建反向引用,在較長的正則表達式中,存儲反向引用會降低匹配速度,通過使用非捕獲性分組,仍然可以擁有與匹配字符串序列同樣的能力,而無需存儲結(jié)果的開銷 

var sToMatch = "#123456789"; 
var reNumbers = /#(?:\d+)/; //只需要在左括號的后面加上一個問號和一個緊跟的冒號就可創(chuàng)建一個非捕獲性分組 
reNumbers.test(sToMatch); 
alert(RegExp.$1); //"",輸出空字符串是因為該分組是非捕獲性的 
alert(sToMatch.replace(reNumbers, "abcd$1")); //輸出結(jié)果是"abcd$1"而不是"abcd123456789",不能使用任何反向引用 

又如: 

String.prototype.stripHTML = function(){ 
 var reTag = /<(?:.|\s)*?>/g; //匹配所有的HTML標簽,防止插入惡意HTML代碼 
 return this.replace(reTag, ""); 
} 

復(fù)雜模式之前瞻:告訴正則表達式運算器向前看一些字符而不移動其位置,存在正向前瞻(檢查接下來出現(xiàn)的是不是某個特定字符集)和負向前瞻(檢查接下來的不應(yīng)該出現(xiàn)的特定字符集) 
正向前瞻(?=n) 匹配任何其后緊接指定字符串 n 的但不包括 n的字符串,注意這里的括號不是分組 
負向前瞻(?!n) 匹配任何其后沒有緊接指定字符串 n 的字符串,如:  

var sToMatch1 = "bedroom"; 
var sToMatch2 = "bedding"; 
var reBed1 = /(bed(?=room))/; 
var reBed2 = /(bed(?!room))/; 
alert(reBed1.test(sToMatch1)); //true 
alert(RegExt.$1); //輸出"bed"而不是"bedroom" 
alert(reBed1.test(sToMatch2)); //false 
alert(reBed2.test(sToMatch1)); //false 
alert(reBed2.test(sToMatch2)); //true 
alert(RegExt.$1); //輸出的也是"bed" 

復(fù)雜模式之邊界:用于正則表達式中表示模式的位置 
n$ 匹配任何結(jié)尾為 n 的字符串,如:/(\w+)\.$/匹配行尾單詞"one.","two."等 
^n 匹配任何開頭為 n 的字符串,如:/^(.+?)\b/匹配起始位置后的一個或多個單詞字符 
\b 查找位于單詞的開頭或結(jié)尾的匹配,如:/\b(\S+?)\b/g 或 /(\w+)/g匹配從字符串中抽取單詞 
\B 查找不處在單詞的開頭或結(jié)尾的匹配 
復(fù)雜模式之多行模式: 

var sToMatch = "First second\nthird fourth\nfifth sixth"; 
var reLastWordOnLine = /(\w+)$/gm; 
alert(sToMatch.match(reLastWordOnLine)); //輸出["second", "fourth", "sixth"]而不只是"sixth" 

RegExp對象的屬性和方法: 
global  //RegExp 對象是否具有標志 g 
ignoreCase  //RegExp 對象是否具有標志 i 
multiline  //RegExp 對象是否具有標志 m 
source  //正則表達式的源文本 
lastIndex  //一個整數(shù),標示下一次匹配鈄會從哪個字符位置開始(只有當使用exec()和test()函數(shù)才會填入,否則為0) 
真正使用到的是lastIndex,如:  

 
var sToMatch = "bbq is short for barbecue"; 
var reB = /b/g; 
reB.exec(sToMatch); 
alert(reB.lastIndex); //1,匹配位置是0,lastIndex為1 
reB.exec(sToMatch); 
alert(reB.lastIndex); //2 
reB.exec(sToMatch); 
alert(reB.lastIndex); //18 
reB.lastIndex = 0; //重頭開始匹配 
reB.exec(sToMatch); 
alert(reB.lastIndex); //1而不是21 

靜態(tài)屬性 
input,短名為$_,最后用于匹配的字符串(傳遞給exec()或test()的字符串) 
leftContext,短名為$^,在上次匹配的前面的子串 
rightContext,短名為$^,在上次匹配之后的子串 
lastMatch,短名為$&,最后匹配的字符 
lastParen,短名為$+,最后匹配的分組 
multiline,短名為$*,用于指定是否所有的表達式都使用多行模式的布爾值,不同于其它屬性,不依賴最后一次執(zhí)行的匹配,它可以設(shè)置所有的正則表達式的m選項,RegExp.multiline = "true";,注意IE和Opera不運行它  

 var sToMatch = "this has been a short, short summer"; 
 var reShort = /(s)hort/g; 
 reShort.test(sToMatch); 
 alert(RegExg.input); //"this has been a short, short summer"; 
 alert(RegExg.leftContext); //"this has been a "; 
 alert(RegExg.rightContext); //", short summer"; 
 alert(RegExg.lastMatch); //"short" 
 alert(RegExg.lastParen); //"s" 
 
compile() //編譯正則表達式 
alert(reCat.exec("a cat, a Cat, a cAt caT")); //返回一個數(shù)組,數(shù)組中的第一個條目是第一個匹配,其他的是反向引用 
alert(reCat.test("cat")); //true,檢索字符串中指定的值,返回 true 或 false。 

支持正則表達式的String對象的方法 

var sToMatch = "a bat, a Cat, a fAt, a faT cat"; 
var reAt = /at/gi; 
alert(sToMatch.match(reAt)); //返回一個包含在字符串中的所有匹配的數(shù)組 
alert(sToMatch.search(reAt)); //輸出第一次在字符串中出現(xiàn)的位置3,全局匹配g在search()時不起作用 
alert(sToMatch.replace(reAt, "Dog")); //替換與正則表達式匹配的子串 
alert(sToMatch.replace(reAt, function(sMatch){ 
 return "Dog"; 
})); 
alert(sToMatch.split(/\,/)); //把字符串分割為字符串數(shù)組 

常用模式 
日期:/(?:0[1-9]|[12][0-9]|3[01])\/(?:0[1-9]|1[0-2])\/(?:19|20\d{2})/ 
URL:/^http://([w-]+.)+[w-]+(/[w-./?%&=]*)?$/ 
E-mail地址:/^(?:\w+\.?)*\w+@(?:\w+\.?)*\w+$/ 
國內(nèi)電話號碼:d{3}-d{8}|d{4}-d{7} 
騰訊QQ號:[1-9][0-9]{4,} 
郵政編碼:[1-9]d{5}(?!d) 
身份證:d{15}|d{18} 
ip地址:d+.d+.d+.d+ 
中文字符: [u4e00-u9fa5] 
雙字節(jié)字符(包括漢字在內(nèi)):[^x00-xff] 
    String.prototype.len=function(){return this.replace([^x00-xff]/g,"aa").length;} 
全角字符:/[^uFF00-uFFFF]/g 
匹配特定數(shù)字: 

^[1-9]\d*$    //匹配正整數(shù) 
^-[1-9]\d*$   //匹配負整數(shù) 
^-?[1-9]\d*$   //匹配整數(shù) 
^[1-9]\d*|0$  //匹配非負整數(shù)(正整數(shù) + 0) 
^-[1-9]\d*|0$   //匹配非正整數(shù)(負整數(shù) + 0) 
^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$   //匹配正浮點數(shù) 
^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$  //匹配負浮點數(shù) 
^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$  //匹配浮點數(shù) 
^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$   //匹配非負浮點數(shù)(正浮點數(shù) + 0) 
^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0+|0$  //匹配非正浮點數(shù)(負浮點數(shù) + 0) 

是不是很全面,很詳細,感覺不錯的就把這文章好好收藏,js正則表達式很重要的學(xué)習(xí)環(huán)節(jié),大家一定好好學(xué)習(xí)。

相關(guān)文章

  • 循序漸進掌握遞歸正則表達式【推薦】

    循序漸進掌握遞歸正則表達式【推薦】

    這篇文章主要介紹了循序漸進掌握遞歸正則表達式的相關(guān)知識,本文給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-08-08
  • [a] 1 [/a]轉(zhuǎn)換為網(wǎng)址的UBB的正則

    [a] 1 [/a]轉(zhuǎn)換為網(wǎng)址的UBB的正則

    [a] 1 [/a]轉(zhuǎn)換為網(wǎng)址的UBB的正則...
    2007-11-11
  • 正則表達式問號的四種用法詳解

    正則表達式問號的四種用法詳解

    這篇文章主要介紹了正則表達式問號的四種用法詳解的相關(guān)資料,需要的朋友可以參考下
    2015-09-09
  • 正則基礎(chǔ)之 NFA引擎匹配原理

    正則基礎(chǔ)之 NFA引擎匹配原理

    不懂正則引擎原理的情況下,同樣可以寫出滿足需求的正則,但是不知道原理,卻很難寫出高效且沒有隱患的正則。所以對于經(jīng)常使用正則,或是有興趣深入學(xué)習(xí)正則的人,還是有必要了解一下正則引擎的匹配原理的。
    2009-07-07
  • 談?wù)勎覍φ齽t表達式的認識

    談?wù)勎覍φ齽t表達式的認識

    正則表達式(Regular Expression)是一個概念,一種語法、句法的約定。每一種具體的語句(C#,Java,JavaScript)有其對于正則表達式的具體實現(xiàn),并且會有差別。正則表達式30分鐘入門教程講述的是.net(C#)的正則表達式
    2014-02-02
  • 55分鐘學(xué)會正則表達式(來自Github)

    55分鐘學(xué)會正則表達式(來自Github)

    正則表達式是一種查找以及字符串替換操作。正則表達式在文本編輯器中廣泛使用,比如正則表達式被用于文本的一些操作,這里雖然說時間有點短,但經(jīng)過一段時期的聯(lián)系,每次正則可能功能更全,代碼量也更好,考慮的也會更周全
    2020-04-04
  • 精確查找PHP WEBSHELL木馬 修正版

    精確查找PHP WEBSHELL木馬 修正版

    上篇提到了關(guān)于網(wǎng)上流傳查找PHP webshell的python腳本中,不嚴謹?shù)拇a,并且給出了一個python的檢測代碼,同時,下文里也提到不能檢測到反引號的命令執(zhí)行的地方。今天,我想了下,現(xiàn)在把思路發(fā)出來。
    2011-04-04
  • 數(shù)據(jù)庫中使用正則表達式小結(jié)

    數(shù)據(jù)庫中使用正則表達式小結(jié)

    這篇文章主要介紹了數(shù)據(jù)庫中使用正則表達式小結(jié)的相關(guān)資料,需要的朋友可以參考下
    2015-10-10
  • Java正則相關(guān)的Pattern和Matcher類及遇到的坑

    Java正則相關(guān)的Pattern和Matcher類及遇到的坑

    這篇文章主要介紹了Java正則相關(guān)的Pattern和Matcher類及遇到的坑,本文給大家提到了Matcher 里面的三個方法,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-09-09
  • 正則表達式中兩個反斜杠的匹配規(guī)則詳解

    正則表達式中兩個反斜杠的匹配規(guī)則詳解

    這篇文章主要介紹了正則表達式中兩個反斜杠的匹配規(guī)則,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11

最新評論