站長資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

javascript正則表達式和字符串RegExp and String(一)

前言

正則表達式是javascript非常重要和常用的功能,在jquery等大型框架中用的非常頻繁,最近抽時間學(xué)習(xí)了解了相關(guān)知識,記錄下來與需要的朋友分享。

思維導(dǎo)圖

javascript正則表達式和字符串RegExp and String(一)

RegExp(正則表達式)的創(chuàng)建方式

可以通過兩種方式創(chuàng)建一個RegExp,具體如下:

通過/…./的方式來創(chuàng)建正則表達式(注意: /……/兩邊是沒有單引號或雙引號的)
通過RegExp構(gòu)造方法來創(chuàng)建一正則表達式
為了更好的描述模式,正則表達式提供了3個標(biāo)識,分別是: g/i/m

g: 全局匹配:在整個字符串中匹配,而不是在第一次匹配后之后停止
i: 忽略大小寫匹配
m: 對多行字符串中的每一行,應(yīng)用行首和行末的特殊字符(分別是^和$)
具體看參照下面代碼加深理解:

  var regx = new RegExp('are','g');  var regx1 = /are/g;  //常用的創(chuàng)建方式

RegExp實例的主要屬性

根據(jù)RegExp的構(gòu)造函數(shù),我們大概也能猜到RegExp的主要屬性,關(guān)于實例屬性,了解下就可以了。但有一點要注意:這些實例屬性是不能通過for in進行遍歷獲取的。

可參照下面代碼加深理解:

  var regx1 = /are/g; //常用的創(chuàng)建方式  console.log("source:"+regx.source +" global:"+regx.global+" ignoreCase:"+regx.ignoreCase +" multiline:"+regx.multiline);  // source:are global:true ignoreCase:false multiline:false    for(var p in regx) { //不會進入該for循環(huán)   if(regx.hasOwnProperty(p)) {   console.log(regx[p]);   }  }

RegExp實例的主要方法 – test

根據(jù)該方法非常簡單,只有一個參數(shù),常用來驗證輸入的參數(shù)與正則表達式模式是否匹配,如果匹配返回true,否則返回false. 可參照下面代碼加深理解:

  var regx1 = /are/g;  var res = regx.test('you are a good boy!');  console.log(res) ; //true  var res1 = regx.test('I am a good boy!');   console.log(res1) ; //false

RegExp實例的主要方法 – exec

法該方法是一個非常常用的方法,需要好好理解。它只接收一個參數(shù),即要匹配的字符串,返回值卻是一個數(shù)組arr,數(shù)組里存儲的是第一個匹配項的相關(guān)信息,包括:

input: 要匹配的字符串,exec方法的輸入值

index:匹配性在字符串中的位置

arr[0]: 模式匹配的字符串

arr[1]…arr[n]: 第n個捕獲組字符串

使用該方法時要注意:如果在正則表達式中未指定全局標(biāo)志g,則每次執(zhí)行始終返回的都是第一個匹配項,如果設(shè)置了全局標(biāo)志g,每次調(diào)用exec,則會在字符串中繼續(xù)查找新匹配項

可參照下面代碼加深理解:

   var regx = /fn:(w+)s+ln:(w+)s/g;   var s ="your fn:xiaoxin ln:tang right?";   var result = regx.exec(s);   console.log(result.input); //your fn:xiaoxin ln:tang right?   console.log(result.index); //5   console.log(result[0]); //fn:xiaoxin ln:tang   console.log(result[1]); //xiaoxin   console.log(result[2]); //tang   console.log(result[3]); //undefined 因為只有2個捕獲組,所以打印undefined

RegExp構(gòu)造函數(shù)屬性

關(guān)于函數(shù)屬性,可以參照其它編程語言(如java)中類的靜態(tài)屬性來理解,這些屬性被所有的RegExp實例共享,也就是所有的RegExp都可以訪問和修改這些屬性,當(dāng)某個實例執(zhí)行test或exec方法時,這些屬性的值也將跟著發(fā)生變化

關(guān)于這些屬性,我們可以按照自己的理解記憶:

input : 需要進行模式匹配的字符串,test或exec方法的輸入?yún)?shù)。 參數(shù)別名: $-
lastMatch : 最近一次匹配項 。 參數(shù)別名:$&
leftContext : 匹配項左邊的字符串。參數(shù)別名:$`
rightContext : 匹配項右邊的字符串 。 參數(shù)別名:$’
1,2,$3….: 捕獲組對應(yīng)的字符串 。

當(dāng)然這些值,完全可以通過RegExp實例執(zhí)行exec返回的結(jié)果計算得到,那為什么要在構(gòu)造函數(shù)RegExp中設(shè)置這些屬性呢?*

可參照下面代碼加深理解:

  var regx = /fn:(w+)s+ln:(w+)s/g;  var s ="your fn:xiaoxin ln:tang right?";  var result = regx.exec(s);  console.log(RegExp.input); //your fn:xiaoxin ln:tang right?  console.log(RegExp.lastMatch); //fn:xiaoxin ln:tang  console.log(RegExp.leftContext); //your  console.log(RegExp.rightContext); //right?  console.log(RegExp.$1); //xiaoxin  console.log(RegExp.$2); //tang

RegExp – 元字符

與其它語言中的正則表達式類似, js正則表達式中也存在一些元字符,這些字符有特殊的用途和含義,所以在使用的過程中,需要對這些字符進行轉(zhuǎn)義,通過在這些字符前加上” 進行轉(zhuǎn)義處理. JS正則表達是的元字符有:

( [ { ^ $ | ) ? * + . ] } 

RegExp – 貪婪匹配和懶惰匹配

貪婪匹配就是在正則表達式的匹配過程中,默認會使得匹配長度越大越好。在JS正則表達式中,懶惰限定符是 ‘?’ ,在模式中添加 ‘?’ 則要求是懶惰匹配。具體參照下面代碼來理解:

  var s = 'I am a good boy,you are also a good boy !';  var regx = /good.*boy/g; //貪婪匹配  console.log(regx.exec(s)[0]); //good boy,you are also a good boy  var regx1 = /good.*?boy/g; //懶惰匹配  console.log(regx1.exec(s)[0]); //good boy

以上內(nèi)容是小編給大家分享的javascript正則表達式和字符串RegExp and String(一),下篇文章給大家分享javascript正則表達式和字符串RegExp and String(二)希望大家喜歡。

贊(0)
分享到: 更多 (0)
網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號
亚洲综合精品香蕉久久网97| 国产在线精品二区赵丽颖| 久久99亚洲综合精品首页| 国产成人一区二区精品非洲| 亚洲国产福利精品一区二区| 亚洲一区精品无码| 日韩精品系列产品| 久9re热视频这里只有精品| 人妻少妇乱子伦精品| 久久e热在这里只有国产中文精品99| 国产精品无码一二区免费| 无码精品A∨在线观看免费| 一区二区三区日韩精品| 亚洲精品少妇30p| 久久夜色精品国产亚洲av| 日韩精品一区二区午夜成人版| 日韩久久无码免费毛片软件| 老牛精品亚洲成av人片| 人妻熟妇乱又伦精品HD| 九九精品久久久久久噜噜| 五月天婷婷精品视频| 揄拍自拍日韩精品| 久久久久女人精品毛片| 99精品国产在这里白浆| 少妇精品无码一区二区三区| 久久久久久人妻一区精品| 久久精品视频16| 国产成人A人亚洲精品无码| 国产女主播精品大秀系列| 亚洲精品成人片在线观看精品字幕| 中文乱码精品一区二区三区| 精品国产午夜福利在线观看| 国产成人亚洲精品91专区手机| 亚洲AV无码之日韩精品| 人人妻人人做人人爽精品| 一区二区三区四区精品| 精品人妻少妇一区二区| 中文字幕精品视频在线观| 99热成人精品热久久669| 精品一区二区三区在线视频| 先锋影音国产精品|