成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

JavaScript正則表達式知識整理

myeveryheart / 431人閱讀

摘要:通過學習課程正則表達式對視頻教學內(nèi)容做一個知識整理。理解這個請看下面方法正則表達式的源文本。簡單的就是找到匹配字符的開始位置找到一個或多個正則表達式的匹配。與有些許相似,只是返回的內(nèi)容更加細節(jié)替換與正則表達式匹配的子串。

通過學習imooc課程《JavaScript正則表達式》對視頻教學內(nèi)容做一個知識整理。視頻源地址:http://www.imooc.com/video/12539

一個正則表達式在線工具:http://regexper.com

JavaScript 通過內(nèi)置對象RegExp支持正則表達式,有兩種方法實例化RegExp對象:

字面量 eg: var reg = /bisb/g;

構造函數(shù) eg: var reg = new RegExp("/bisb/","g" );

1.修飾符

g:global全文搜索,不添加,搜索到第一個匹配停止;

i:ignore case忽略大小寫;

m:multiple lines多行搜索;

2.元字符

正則表達式有兩種基本字符類型組成:

原義文本字符,即要找什么就是什么,要找a就直接寫a,找123就直接寫123;
元字符,有特殊含義的非字母字符:* ? + $ ^ . | ( ) { } [ ];
其他的還有:

3.元字符

一般情況正則表達式一個字符對應字符串一個字符,eg 表達式abt含義是 "ab" tab制表符;一般由元字符 [ ] 來構建一個簡單的類,不是特指某個字符,eg [abc]把字符a或b或c歸為一類;在[ ]里面加 ^ 表示取反,eg 1代表不要有a或b或c;

4.范圍類

用[a-zA-Z0-9]來代表a到z或A到Z貨0到9中任意字符;

5.預定義類

6.量詞

再有很常用的 ^n 匹配任何開頭為 n 的字符串 ; n$匹配任何結尾為 n 的字符串。

還有一個易混淆的,?=n 匹配任何其后緊接指定字符串 n 的字符串。就是說要找到的這個字符后面一定要跟字符n

  var reg = "a1b1c1ddeeff"; 

 reg.replace(/w(?=d)/g,"Y"); 

結果是"Y1Y1Y1ddeeff" ;
與之相反的就是 !?=n;

7.貪婪模式、非貪婪模式

正則表達式在默認下是盡可能多的匹配,eg "123456789".replace(/d{2,5}/g,"X"); 結果是X6789,默認貪婪模式,以{2,5}范圍中最大的為標準匹配。

要設置成非貪婪模式可以"123456789".replace(/d{2,5}?/g,"X");結果為XXXX9,即按{2,5}中最小的2來匹配,12,34,56,78都匹配成功變成X,剩下9沒有匹配成功

8.分組

使用()可以達到分組功能,使量詞作用于分組,eg "a1b1c1d2".replace(/[a-z]d{3}/g,"x");這里{3}是直接作用與最接近的d,即找[a-z]然后連續(xù)出現(xiàn)3個數(shù)字,"a1b1c1d2".replace(/([a-z]d){3}/g,"x");這樣就能找到連續(xù)出現(xiàn)三次(一個字母加一個數(shù)字),就是"a1b1c1"這個字符串了;

9.對象屬性

global(只可讀,不可寫)

ignoreCase(只可讀,不可寫)

multiline(只可讀,不可寫)

lastIndex 一個整數(shù),標示開始下一次匹配的字符位置。(理解這個請看下面方法test())

source 正則表達式的源文本。

10.方法

test() 檢索字符串中指定的值。返回 true 或 false。

exec() 檢索字符串中指定的值。返回找到的值,并確定其位置。

compile() 編譯正則表達式。
test(): eg var reg = /w/g; reg.test("ab");結果是true,但多執(zhí)行幾次會發(fā)現(xiàn)

最后一個結果變成false,這其實和RegExp屬性lastIndex有關,

var reg = /w/g;
while(reg.test("ab")){
  console.log(reg.lastIndex);
}

結果是1,2,這是因為第一次test會匹配到a,這時lastIndex就是這個字符a的下一位,即b的位置1,接著test還會繼續(xù)向后面匹配,輪到這個b,這是lastIndex就是b后面的位置2,之后會重置為0,從頭開始循環(huán)。要避免這種test出現(xiàn)不穩(wěn)定輸出,可以直接/w/g.test("ab");

exec() :返回一個數(shù)組,其中存放匹配的結果。如果未找到匹配,則返回值為 null。借用w3school上的話,如果 exec() 找到了匹配的文本,則返回一個結果數(shù)組。否則,返回 null。此數(shù)組的第 0 個元素是與正則表達式相匹配的文本,第 1 個元素是與 RegExpObject 的第 1 個子表達式相匹配的文本(如果有的話),第 2 個元素是與 RegExpObject 的第 2 個子表達式相匹配的文本(如果有的話),以此類推。

看代碼:

var reg = /d(w)(w)d/;
var str = "1ax2by3cz4d5e";
var ret =  reg.exec(str);
console.log(ret);

輸出:["1ax2", "a", "x"]
這里返回的數(shù)組第一個就是匹配到的1a2,然后第二和第三個數(shù)組就是1a2中間的a和x,因為/d(w)d/里面的子表達式就是(w)(w);

同樣的來看正則對象的lastIndex屬性,以及匹配結果的數(shù)組的index屬性:

var reg = /d(w)(w)d/g;
var str = "$1ax2by3cz4dd5ee";

while(ret = reg.exec(str)){
  console.log(reg.lastIndex + "	" + ret.index + "	" + ret);
}

輸出:
"5 1 1ax2,a,x"

"11 7 3cz4,c,z"

  第一個:5,指第一次匹配后reg對象的lastIndex(紅色后面的位置),1指的是exec()方法返回的位置,$后面開始匹配到的,所以是1;

  第二個:11,指第一次匹配后reg對象的lastIndex(藍色后面的位置),7指exec()方法返回的位置,y后面開始匹配到的,所以是7;

compile():我的理解是可以修改正則表達式,看代碼

function CompileDemo(){
   var rs;
   var s = "AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPp"
   var r = new RegExp("[A-Z]", "g");
   var a1 = s.match(r); 

   r.compile("[a-z]", "g");
   var a2 = s.match(r);       
       
   return(a1 + "
" + a2);
}

console.log(CompileDemo());

輸出:
"A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P
a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p"

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

search() 檢索與正則表達式相匹配的值。(簡單的就是找到匹配字符的開始位置)

match() 找到一個或多個正則表達式的匹配。(與exec()有些許相似,只是exec()返回的內(nèi)容更加細節(jié))

replace() 替換與正則表達式匹配的子串。(這個不多說)

split() 把字符串分割為字符串數(shù)組。(這個也容易,就是注意別忘了)

(這里要注意10 和 11 是完全對應不同對象的方法,一個是RegExp對象的方法,一個是String對象的方法)

這部分主要在JavaScript string對象部分有學習到,可以參考http://www.w3school.com.cn/js...

abc ?

文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/87395.html

相關文章

  • 正則達式

    摘要:本文內(nèi)容共正則表達式火拼系列正則表達式回溯法原理學習正則表達式,是需要懂點兒匹配原理的。正則表達式迷你書問世了讓幫你生成和解析參數(shù)字符串最全正則表達式總結驗證號手機號中文郵編身份證地址等是正則表達式的縮寫,作用是對字符串執(zhí)行模式匹配。 JS 的正則表達式 正則表達式 一種幾乎可以在所有的程序設計語言里和所有的計算機平臺上使用的文字處理工具。它可以用來查找特定的信息(搜索),也可以用來查...

    bang590 評論0 收藏0
  • JavaScript 正則達式迷你書》知識點小抄本

    摘要:介紹這周開始學習老姚大佬的正則表達式迷你書,然后習慣性的看完一遍后,整理一下知識點,便于以后自己重新復習。感謝原書作者老姚,本文無意抄襲,只是作為自己知識點的整理,后續(xù)也會整理到自己的知識庫網(wǎng)站中。等價于,表示出現(xiàn)次。 showImg(https://segmentfault.com/img/remote/1460000018530584?w=919&h=449); 介紹 這周開始學習...

    zollero 評論0 收藏0
  • 【連載】前端個人文章整理-從基礎到入門

    摘要:個人前端文章整理從最開始萌生寫文章的想法,到著手開始寫,再到現(xiàn)在已經(jīng)一年的時間了,由于工作比較忙,更新緩慢,后面還是會繼更新,現(xiàn)將已經(jīng)寫好的文章整理一個目錄,方便更多的小伙伴去學習。 showImg(https://segmentfault.com/img/remote/1460000017490740?w=1920&h=1080); 個人前端文章整理 從最開始萌生寫文章的想法,到著手...

    madthumb 評論0 收藏0
  • PHP小知識

    摘要:那些瑣碎的知識點作者記錄的的很奇特很難記的知識點。易錯知識點整理注意和的區(qū)別中和都是輸出的作用,但是兩者之間還是有細微的差別。今天手頭不忙,總結一下,分享過程中掌握的知識點。 深入理解 PHP 之:Nginx 與 FPM 的工作機制 這篇文章從 Nginx 與 FPM 的工作機制出發(fā),探討配置背后的原理,讓我們真正理解 Nginx 與 PHP 是如何協(xié)同工作的。 PHP 那些瑣碎的知識...

    hover_lew 評論0 收藏0

發(fā)表評論

0條評論

myeveryheart

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<