婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > javascript正則表達式RegExp入門圖文教程

javascript正則表達式RegExp入門圖文教程

熱門標簽:甘肅醫療外呼系統排名 西藏智能外呼系統代理商 ai電話機器人搭建 呼叫系統外呼只能兩次 梅縣地圖標注 400電話辦理電話辦理 外呼系統無呼出路由是什么原因 地圖標注教學點 貴港公司如何申請400電話

正則表達式是啥?

正則表達式又叫作“規則表達式”(Regular Expression 即 RegExp),是計算機科學的一個概念。

正則表達式有什么用?

它常被用來搜索、替換那些符合某個模式的文本。

正則表達式是:用來匹配特殊字符或有特殊搭配原則的字符的最佳選擇。

轉義字符“\”

例子:在var str = "asdfghj" 中加入一個"字符在正常情況下是無法成立的,但運用正則表達式中的轉義字符則"\"可以讓他成立;

在”前加入轉義符“\”可以使得變量成立,在圖中轉義字符+雙引號成功變為一個文本符號這時在瀏覽器中就可以輸出"asdf"ghjs"

字符串換行符\n

例子:在var str = "asdfghj" 中進行換行

得到結果

如何創建正則表達式

1.直接量

var reg = //;在斜線之間寫內容

var reg = /abc/; 表示匹配一個規則abc,在 var str = "abcdef";通過reg.test(str)對str進行測試是否含有reg規定的字符串,若有返回true,若沒有返回false

在//后可寫屬性值 (i, m, g)

2.new RegExp()


效果同直接量含有正則表達式中的值返回true,若不含有返回false

在RegExp中可寫屬性值:RegExp("abc",參數(i,g,m))

正則表達式的三個修飾符: i, m, g

i: 不區分大小寫

m:執行多行匹配

var reg = /^a/;表示查找的開頭字符為a的,這時間str中沒有符合此要求的字符,但若在reg = /^a/m;實行多行匹配,則可以識別換行符\n。在有換行符時認為\n前為一行、\n后為一行

g: 執行全局匹配 (查找所有匹配而非在找到第一個匹配后停止)

正則表達式中的方法:reg.test(); 返回結果true/false

變量中的方法:str.match(); 可將結果返回出來,效果更為直觀

表達式

[]:可在[]寫入范圍



[^abc]:開頭為abc

[0-9]:范圍0-9

[a-z]:范圍a-z

[A-Z]范圍A-Z

[A-z]范圍A-Z,a-z

|:表示或


元字符:

\w:單詞字符

\W:非單詞字符

\d:數字

\D:非數字

\s:空白字符(包含:空格符,制表符,回車符,換行符,垂直換行符,換頁符)

\S:非空白字符

\n:換行符

\r:回車符

\b:單詞邊界

\B:非單詞邊界

\t:制表符

. :表示除了\r\n外的所有字符

量詞(以下n為代表數量的詞)

n+:可以出現1到無數次

n*:可以出現0到無數次,末尾邏輯距離算為空

n?可以出現0或一個字符串,邏輯距離為空

n{X}:可以出現X個n的字符串

n{X,Y}:匹配包含X至Y個n的字符串(符合貪婪匹配原則能多就不少)

n{X,}:匹配包含至少X個n的字符串(符合貪婪匹配原則能多就不少)

^n:以n開頭

n$:以n結尾

ReegExp對象屬性:

ignoreCase:RegExp對象是否含有修飾符i

global: RegExp對象是否含有修飾符g

multiline: RegExp對象是否含有修飾符m

source: 顯示正則表達式函數體

正則表達式方法:

test:檢查字符串中指定的值。返回ture/false

exec:檢查字符串中指定的值。返回值并確定其位置。

匹配的位置隨著其光標的起始位置變化而變化。當光標移動到最后位會返回null,再次執行則會從頭執行

下圖中

"ab"未返回值,

index為光標位置

字符串對象的方法:

match:找到一個或多個正則表達式的匹配。返回匹配值。

search:檢查與正則表達式相匹配的值,返回其光標所處的位置。如果匹配不到返回-1.

split:拆分字符串。

replace:替換與正則表達式相匹配的字符串。

例子:將var str = "aabb"替換為"bbaa"

1. var reg = /(\w)\1(\w)\2/g;

console.log(str.replace(reg,"$2$2$1$1"));

\\輸出結果為:"bbaa"

2. var reg = /(\w)\1(\w)\2/g;

console.log(str.replace(reg, function ($, $1, $2) {

return $2 + $2 + $1 + $1;

}));

\\輸出結果為:"bbaa"

其中$為正則表達式全局,$1為第一個自變量 "(\w)\1",$2代表第二個自變量"(\w)\2";

例子:the-first-name 變為小頭峰模式(theFirstName);

其中$為正則表達式全局,$1為第一個自變量 "-(\w)"

正向預查(正向斷言):在正則中只參與限定不參與選擇

1.在正則表達式中查看 var str = "abaaaa"中身后帶b的字符串,但輸出時不顯示b字符;

var str = "abaaaa";

var reg = /a(? = b)/g; //表示a后面跟著b但b參與選擇只參與限定

2. 在正則表達式中查看 var str = "abaaaa"中身后不帶b的字符串;

var reg = /a(? !b)/g; //表示查找a后沒有b字符的字符串;

非貪婪匹配:正則表達式中默認貪婪匹配,但我們可以通過方法將貪婪匹配變為非貪婪匹配。在任何量詞后加?

reg = /n{1,}/ ; //這時n的個數在1~無窮大之間,而在貪婪匹配的作用下,取值個數會盡可能變大;

reg = /n(1,)?/ ; //在n(1,)后加入?,這時正則匹配,取值會以最小個數為基準;

2. 正則表達式中的一些高級規則

2.1 匹配次數中的貪婪與非貪婪

在使用修飾匹配次數的特殊符號時,有幾種表示方法可以使同一個表達式能夠匹配不同的次數,比如:"{m,n}", "{m,}", "?", "*", "+",具體匹配的次數隨被匹配的字符串而定。這種重復匹配不定次數的表達式在匹配過程中,總是盡可能多的匹配。比如,針對文本 "dxxxdxxxd",舉例如下:

表達式

匹配結果
(d)(\w+) "\w+" 將匹配第一個 "d" 之后的所有字符 "xxxdxxxd"
(d)(\w+)(d) "\w+" 將匹配第一個 "d" 和最后一個 "d" 之間的所有字符 "xxxdxxx"。雖然 "\w+" 也能夠匹配上最后一個 "d",但是為了使整個表達式匹配成功,"\w+" 可以 "讓出" 它本來能夠匹配的最后一個 "d"

由此可見,"\w+" 在匹配的時候,總是盡可能多的匹配符合它規則的字符。雖然第二個舉例中,它沒有匹配最后一個 "d",但那也是為了讓整個表達式能夠匹配成功。同理,帶 "*" 和 "{m,n}" 的表達式都是盡可能地多匹配,帶 "?" 的表達式在可匹配可不匹配的時候,也是盡可能的 "要匹配"。這 種匹配原則就叫作 "貪婪" 模式 。

非貪婪模式:

在修飾匹配次數的特殊符號后再加上一個 "?" 號,則可以使匹配次數不定的表達式盡可能少的匹配,使可匹配可不匹配的表達式,盡可能的 "不匹配"。這種匹配原則叫作 "非貪婪" 模式,也叫作 "勉強" 模式。如果少匹配就會導致整個表達式匹配失敗的時候,與貪婪模式類似,非貪婪模式會最小限度的再匹配一些,以使整個表達式匹配成功。舉例如下,針對文本 "dxxxdxxxd" 舉例:

表達式

匹配結果
(d)(\w+?) "\w+?" 將盡可能少的匹配第一個 "d" 之后的字符,結果是:"\w+?" 只匹配了一個 "x"
(d)(\w+?)(d) 為了讓整個表達式匹配成功,"\w+?" 不得不匹配 "xxx" 才可以讓后邊的 "d" 匹配,從而使整個表達式匹配成功。因此,結果是:"\w+?" 匹配 "xxx"

更多的情況,舉例如下:

舉例1:表達式 "td>(.*)/td>" 與字符串 "td>p>aa/p>/td> td>p>bb/p>/td>" 匹配時,匹配的結果是:成功;匹配到的內容是 "td>p>aa/p>/td> td>p>bb/p>/td>" 整個字符串, 表達式中的 "/td>" 將與字符串中最后一個 "/td>" 匹配。

舉例2:相比之下,表達式 "td>(.*?)/td>" 匹配舉例1中同樣的字符串時,將只得到 "td>p>aa/p>/td>", 再次匹配下一個時,可以得到第二個 "td>p>bb/p>/td>"。

2.2 反向引用 \1, \2...

表達式在匹配時,表達式引擎會將小括號 "( )" 包含的表達式所匹配到的字符串記錄下來。在獲取匹配結果的時候,小括號包含的表達式所匹配到的字符串可以單獨獲取。這一點,在前面的舉例中,已經多次展示了。在實際應用場合中,當用某種邊界來查找,而所要獲取的內容又不包含邊界時,必須使用小括號來指定所要的范圍。比如前面的 "td>(.*?)/td>"。

其實,"小括號包含的表達式所匹配到的字符串" 不僅是在匹配結束后才可以使用,在匹配過程中也可以使用。表達式后邊的部分,可以引用前面 "括號內的子匹配已經匹配到的字符串"。引用方法是 "\" 加上一個數字。"\1" 引用第1對括號內匹配到的字符串,"\2" 引用第2對括號內匹配到的字符串……以此類推,如果一對括號內包含另一對括號,則外層的括號先排序號。換句話說,哪一對的左括號 "(" 在前,那這一對就先排序號。

舉例如下:

舉例1:表達式 "('|")(.*?)(\1)" 在匹配 " 'Hello', "World" " 時,匹配結果是:成功;匹配到的內容是:" 'Hello' "。再次匹配下一個時,可以匹配到 " "World" "。

舉例2:表達式 "(\w)\1{4,}" 在匹配 "aa bbbb abcdefg ccccc 111121111 999999999" 時,匹配結果是:成功;匹配到的內容是 "ccccc"。再次匹配下一個時,將得到 999999999。這個表達式要求 "\w" 范圍的字符至少重復5次, 注意與 "\w{5,}" 之間的區別。

舉例3:表達式 "(\w+)\s*(\w+(=('|").*?\4)?\s*)*>.*?/\1>" 在匹配 "td id='td1' style="bgcolor:white">/td>" 時,匹配結果是成功。如果 "td>" 與 "/td>" 不配對,則會匹配失敗;如果改成其他配對,也可以匹配成功。

2.3 預搜索,不匹配;反向預搜索,不匹配

前面的章節中,我講到了幾個代表抽象意義的特殊符號:"^","$","\b"。它們都有一個共同點,那就是:它們本身不匹配任何字符,只是對 "字符串的兩頭" 或者 "字符之間的縫隙" 附加了一個條件。理解到這個概念以后,本節將繼續介紹另外一種對 "兩頭" 或者 "縫隙" 附加條件的,更加靈活的表示方法。

正向預搜索:"(?=xxxxx)","(?!xxxxx)"

格式:"(?=xxxxx)",在被匹配的字符串中,它對所處的 "縫隙" 或者 "兩頭" 附加的條件是:所在縫隙的右側,必須能夠匹配上 xxxxx 這部分的表達式。因為它只是在此作為這個縫隙上附加的條件,所以它并不影響后邊的表達式去真正匹配這個縫隙之后的字符。這就類似 "\b",本身不匹配任何字符。"\b" 只是將所在縫隙之前、之后的字符取來進行了一下判斷,不會影響后邊的表達式來真正的匹配。

舉例1:表達式 "Windows (?=NT|XP)" 在匹配 "Windows 98, Windows NT, Windows 2000" 時,將只匹配 "Windows NT" 中的 "Windows ",其他的 "Windows " 字樣則不被匹配。

舉例2:表達式 "(\w)((?=\1\1\1)(\1))+" 在匹配字符串 "aaa ffffff 999999999" 時,將可以匹配6個"f"的前4個,可以匹配9個"9"的前7個。這個表達式可以讀解成:重復4次以上的字母數字,則匹配其剩下最后2位之前的部分。當然,這個表達式可以不這樣寫,在此的目的是作為演示之用。

格式:"(?!xxxxx)",所在縫隙的右側,必須不能匹配 xxxxx 這部分表達式。

舉例3:表達式 "((?!\bstop\b).)+" 在匹配 "fdjka ljfdl stop fjdsla fdj" 時,將從頭一直匹配到 "stop" 之前的位置,如果字符串中沒有 "stop",則匹配整個字符串。

舉例4:表達式 "do(?!\w)" 在匹配字符串 "done, do, dog" 時,只能匹配 "do"。在本條舉例中,"do" 后邊使用 "(?!\w)" 和使用 "\b" 效果是一樣的。

反向預搜索:"(?=xxxxx)","(?!xxxxx)"

這兩種格式的概念和正向預搜索是類似的,反向預搜索要求的條件是:所在縫隙的 "左側",兩種格式分別要求必須能夠匹配和必須不能夠匹配指定表達式,而不是去判斷右側。與 "正向預搜索" 一樣的是:它們都是對所在縫隙的一種附加條件,本身都不匹配任何字符。

舉例5:表達式 "(?=\d{4})\d+(?=\d{4})" 在匹配 "1234567890123456" 時,將匹配除了前4個數字和后4個數字之外的中間8個數字。由于 JScript.RegExp 不支持反向預搜索,因此,本條舉例不能夠進行演示。很多其他的引擎可以支持反向預搜索,比如:Java 1.4 以上的 java.util.regex 包,.NET 中System.Text.RegularExpressions 命名空間,以及本站推薦的最簡單易用的 DEELX 正則引擎。

標簽:湖州 涼山 常州 本溪 大興安嶺 泰安 海口 哈密

巨人網絡通訊聲明:本文標題《javascript正則表達式RegExp入門圖文教程》,本文關鍵詞  javascript,正則,表達式,RegExp,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《javascript正則表達式RegExp入門圖文教程》相關的同類信息!
  • 本頁收集關于javascript正則表達式RegExp入門圖文教程的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲成人精品影院| 水野朝阳av一区二区三区| 欧美经典一区二区三区| 久久99国内精品| 日韩亚洲欧美成人一区| 午夜天堂影视香蕉久久| 9191久久久久久久久久久| 亚洲不卡一区二区三区| 色综合色综合色综合| 一区二区三区四区五区视频在线观看| 色综合久久综合网| 午夜影院久久久| 欧美成人video| 国产成人av在线影院| 亚洲欧美一区二区视频| 91极品视觉盛宴| 久久精品噜噜噜成人av农村| 国产欧美一区二区精品性| a级精品国产片在线观看| 一级精品视频在线观看宜春院 | 国产老肥熟一区二区三区| 国产午夜亚洲精品午夜鲁丝片 | 久久免费午夜影院| eeuss鲁片一区二区三区| 亚洲gay无套男同| 国产农村妇女毛片精品久久麻豆 | 国产精品第四页| 在线观看精品一区| 亚洲图片欧美一区| 国产色综合一区| 欧美日韩精品欧美日韩精品一 | 久久综合一区二区| 91在线视频在线| 久久精品免费观看| 中文字幕一区二区三区色视频| 欧美美女bb生活片| 成人免费视频caoporn| 青青草成人在线观看| 亚洲人成在线播放网站岛国| 精品国产一区二区在线观看| 欧美在线你懂得| 97久久人人超碰| 国产在线播放一区二区三区| 亚洲一区二区高清| 亚洲人成电影网站色mp4| wwwwxxxxx欧美| 777久久久精品| 欧美亚洲高清一区| av中文字幕亚洲| 狠狠色综合色综合网络| 亚洲成人免费在线| 一区二区三国产精华液| 久久精品一区蜜桃臀影院| 欧美精品自拍偷拍动漫精品| 99国产精品久久| 国产成人在线网站| 国产毛片精品视频| 久久99精品久久久久久国产越南| 亚瑟在线精品视频| 亚洲国产精品影院| 亚洲综合在线电影| 亚洲精品免费在线| 亚洲天堂2016| 亚洲精品videosex极品| 亚洲欧洲制服丝袜| 亚洲综合丝袜美腿| 日产国产欧美视频一区精品| 日韩精品一区第一页| 日欧美一区二区| 久久电影国产免费久久电影| 日本免费在线视频不卡一不卡二| 亚洲精品你懂的| 一区2区3区在线看| 日韩精品乱码av一区二区| 日本vs亚洲vs韩国一区三区二区 | 亚洲一区精品在线| 一区二区三区在线不卡| 亚洲在线成人精品| 香蕉久久一区二区不卡无毒影院| 日韩经典一区二区| 国产一区二区主播在线| 成人avav影音| 欧美熟乱第一页| 欧美成人在线直播| 中文久久乱码一区二区| 国产成人精品一区二区三区网站观看| 美女任你摸久久| 国产精品一二三在| 在线免费视频一区二区| 日韩一区二区三区电影在线观看| 久久品道一品道久久精品| 亚洲色欲色欲www| 婷婷国产在线综合| 成人免费毛片片v| 欧美老人xxxx18| 精品av久久707| 亚洲精选免费视频| 精品一区二区三区久久久| 99麻豆久久久国产精品免费| 欧美久久婷婷综合色| 久久免费精品国产久精品久久久久 | 国产成人啪午夜精品网站男同| 国产成人av一区二区| 91国偷自产一区二区开放时间| 67194成人在线观看| 国产精品三级视频| 日韩经典中文字幕一区| a在线欧美一区| 精品剧情v国产在线观看在线| 久久精品在线观看| 午夜av一区二区三区| 国产不卡视频在线观看| 成人免费观看视频| 欧美成人精精品一区二区频| 综合色中文字幕| 国内精品久久久久影院色| 欧美日韩黄色一区二区| 国产精品家庭影院| 国产伦精一区二区三区| 91精品国产综合久久精品麻豆| 亚洲免费毛片网站| 9久草视频在线视频精品| 久久综合九色综合欧美98| 秋霞成人午夜伦在线观看| 欧美影院一区二区三区| 中文字幕亚洲在| a4yy欧美一区二区三区| 久久久91精品国产一区二区精品| 天天亚洲美女在线视频| 中文字幕乱码一区二区免费| 日本女人一区二区三区| 成人动漫一区二区在线| 日韩欧美一区二区视频| 亚洲成人av一区二区三区| 成人免费视频caoporn| 国产欧美精品一区二区三区四区| 日日欢夜夜爽一区| 欧美中文字幕一区二区三区亚洲| 久久精品免视看| 国产毛片精品一区| 国产亚洲欧美日韩日本| 国产精品一区二区在线观看不卡| 欧美天堂亚洲电影院在线播放| 亚洲欧美色图小说| 欧美私模裸体表演在线观看| 亚洲午夜精品在线| 欧美精品久久天天躁| 日本不卡的三区四区五区| 日韩精品一区二| 国产一区二区在线观看免费| 欧美大胆一级视频| 成人小视频免费在线观看| 中文字幕亚洲一区二区va在线| 1024精品合集| 91豆麻精品91久久久久久| 午夜久久久久久电影| 欧美成人精品福利| 国产宾馆实践打屁股91| 国产精品入口麻豆九色| 欧美在线免费播放| 视频精品一区二区| 久久嫩草精品久久久精品| 99精品视频一区| 日本女人一区二区三区| 久久久久88色偷偷免费| 91丨九色丨蝌蚪富婆spa| 五月婷婷激情综合| 欧美国产精品久久| 欧美性淫爽ww久久久久无| 国产一本一道久久香蕉| 亚洲乱码国产乱码精品精的特点 | 亚洲精品成a人| 欧美一卡二卡三卡| 狠狠狠色丁香婷婷综合激情| 久久久久久久综合| 欧美日韩高清不卡| 成人ar影院免费观看视频| 日韩综合在线视频| 亚洲欧美一区二区久久| 久久网站热最新地址| 欧美日韩精品二区第二页| 国产成人自拍在线| 麻豆精品视频在线观看视频| 亚洲色图制服丝袜| 亚洲成人av在线电影| 国产精品情趣视频| 精品电影一区二区三区| 欧美三级电影在线看| av中文一区二区三区| 国产一区欧美日韩| 免费观看在线综合| 6080午夜不卡| 91麻豆高清视频| 成人免费av网站| 美国三级日本三级久久99 | 亚洲va韩国va欧美va精品| 久久理论电影网| 91精品国产乱| 91视频一区二区| 成人国产精品免费观看视频|