校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > Javascript中正則表達式的使用及基本語法

Javascript中正則表達式的使用及基本語法

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

前面的話

  正則表達式在人們的印象中可能是一堆無法理解的字符,但就是這些符號卻實現了字符串的高效操作。通常的情況是,問題本身并不復雜,但沒有正則表達式就成了大問題。javascript中的正則表達式作為相當重要的知識,本文將介紹正則表達式的基礎語法

定義

  正則表達式(Regular Expression)是一門簡單語言的語法規范,是強大、便捷、高效的文本處理工具,它應用在一些方法中,對字符串中的信息實現查找、替換和提取操作

  javascript中的正則表達式用RegExp對象表示,有兩種寫法:一種是字面量寫法;另一種是構造函數寫法

正則表達式用來處理字符串特別好用,在JavaScript中能用到正則表達式的地方有很多,本文對正則表達式基礎知識和Javascript中正則表達式的使用做一個總結。

第一部分簡單列舉了正則表達式在JavaScript中的使用場景;第二部分詳細介紹正則表達式的基礎知識,寫出一些例子方便理解。

本文的內容是我自己看完正則表達式寫法,和犀牛書中js正則表達式的章節后的總結,所以內容可能會有疏漏和不嚴謹的地方。若有大神路過發現文中錯誤的地方,歡迎斧正!

Javascript中正則表達式的使用

一個正則表達式可以認為是對一種字符片段的特征描述,而它的作用就是從一堆字符串中找出滿足條件的子字符串。比如我在JavaScript中定義一個正則表達式:

var reg=/hello/  或者 var reg=new RegExp("hello")

那么這個正則表達式可以用來從一堆字符串中找出 hello 這個單詞。而“找出”這個動作,其結果可能是找出第一個hello的位置、用別的字符串替換hello、找出所有hello等等。下面就列舉一下JavaScript中可以使用正則表達式的函數,簡單介紹一下這些函數的作用,更復雜的用法會在第二部分中介紹。

String.prototype.search方法

用來找出原字符串中某個子字符串首次出現的index,沒有則返回-1

"abchello".search(/hello/); // 3

String.prototype.replace方法

用來替換字符串中的子串

"abchello".replace(/hello/,"hi");  // "abchi"

String.prototype.split方法

用來分割字符串

"abchelloasdasdhelloasd".split(/hello/); //["abc", "asdasd", "asd"]

String.prototype.match方法

用來捕獲字符串中的子字符串到一個數組中。默認情況下只捕獲一個結果到數組中,正則表達式有”全局捕獲“的屬性時(定義正則表達式的時候添加參數g),會捕獲所有結果到數組中

"abchelloasdasdhelloasd".match(/hello/); //["hello"]
"abchelloasdasdhelloasd".match(/hello/g); //["hello","hello"]

作為match參數的正則表達式在是否擁有全局屬性的情況下,match方法的表現還不一樣,這一點會在后邊的正則表達式分組中講到。

RegExp.prototype.test方法

用來測試字符串中是否含有子字符串

/hello/.test("abchello"); // true

RegExp.prototype.exec方法

和字符串的match方法類似,這個方法也是從字符串中捕獲滿足條件的字符串到數組中,但是也有兩個區別。

1. exec方法一次只能捕獲一份子字符串到數組中,無論正則表達式是否有全局屬性

var reg=/hello/g;
reg.exec("abchelloasdasdhelloasd");  // ["hello"] 

2. 正則表達式對象(也就是JavaScript中的RegExp對象)有一個lastIndex屬性,用來表示下一次從哪個位置開始捕獲,每一次執行exec方法后,lastIndex就會往后推,直到找不到匹配的字符返回null,然后又從頭開始捕獲。 這個屬性可以用來遍歷捕獲字符串中的子串。

var reg=/hello/g;
reg.lastIndex; //0
reg.exec("abchelloasdasdhelloasd"); // ["hello"]
reg.lastIndex; //8
reg.exec("abchelloasdasdhelloasd"); // ["hello"]
reg.lastIndex; //19
reg.exec("abchelloasdasdhelloasd"); // null
reg.lastIndex; //0

正則表達式基礎

元字符

 上面第一節以/hello/為例,但是實際應用中可能會遇到這樣的需求: 匹配一串不確定的數字、匹配開始的位置、匹配結束的位置、匹配空白符。此時就可以用到元字符。

元字符:

//匹配數字: \d
"ad3ad2ad".match(/\d/g); // ["3", "2"]
//匹配除換行符以外的任意字符: .
"a\nb\rc".match(/./g); // ["a", "b", "c"]
//匹配字母或數字或下劃線 : \w
"a5_ 漢字@!-=".match(/\w/g); // ["a", "5", "_"]
//匹配空白符:\s
"\n \r".match(/\s/g); //[" ", " ", ""] 第一個結果是\n,最后一個結果是\r
//匹配【單詞開始或結束】的位置 : \b
"how are you".match(/\b\w/g); //["h", "a", "y"] 
// 匹配【字符串開始和結束】的位置: 開始 ^ 結束 $
"how are you".match(/^\w/g); // ["h"]

反義元字符,寫法就是把上面的小寫字母變成大寫的,比如 , 匹配所有不是數字的字符: \D

另外還有一些用來表示重復的元字符,會在下面的內容中介紹。

字符范圍

在 [] 中使用符號 -  ,可以用來表示字符范圍。如:

// 匹配字母 a-z 之間所有字母
/[a-z]/
// 匹配Unicode中 數字 0 到 字母 z 之間的所有字符
/[0-z]/ 
// unicode編碼查詢地址:
//https://en.wikibooks.org/wiki/Unicode/Character_reference/0000-0FFF
//根據上面的內容,我們可以找出漢字的Unicode編碼范圍是 \u4E00 到 \u9FA5,所以我們可以寫一個正則表達式來判斷一個字符串中是否有漢字
/[\u4E00-\u9FA5]/.test("測試"); // true

重復 貪婪與懶惰

首先來講重復,當我們希望匹配一些重復的字符時,就需要用到一些和重復相關的正則表達式,寫法如下

//重復n次 {n}
"test12".match(/test\d{3}/); // null
"test123".match(/test\d{3}/); // ["test123"]
//重復n次或更多次 {n,}
"test123".match(/test\d{3,}/); // ["test123"]
//重復n到m次
"test12".match(/test\d{3,5}/); // null
"test12345".match(/test\d{3,5}/); // ["test12345"]
"test12345678".match(/test\d{3,5}/); // ["test12345"]
// 匹配字符test后邊跟著數字,數字重復0次或多次
"test".match(/test\d*/); // ["test"]
"test123".match(/test\d*/); // ["test123"]
//重復一次或多次
"test".match(/test\d+/) ; // null
"test1".match(/test\d*/); //["test1"]
//重復一次或0次
"test".match(/test\d?/) ; // null
"test1".match(/test\d?/); //["test1"]

從上面的結果可以看到,字符test后邊跟著的數字可以重復0次或多次時,正則表達式捕獲的子字符串會返回盡量多的數字,比如/test\d*/匹配 test123 ,返回的是test123,而不是test或者test12。

正則表達式捕獲字符串時,在滿足條件的情況下捕獲盡可能多的字符串,這就是所謂的“貪婪模式”。

對應的”懶惰模式“,就是在滿足條件的情況下捕獲盡可能少的字符串,使用懶惰模式的方法,就是在字符重復標識后面加上一個 "?",寫法如下

// 數字重復3~5次,滿足條件的情況下返回盡可能少的數字
"test12345".match(/test\d{3,5}?/); //["test123"]
// 數字重復1次或更多,滿足條件的情況下只返回一個數字
"test12345".match(/test\d+?/); // ["test1"]

字符轉義

在正則表達式中元字符是有特殊的含義的,當我們要匹配元字符本身時,就需要用到字符轉義,比如:

/\./.test("."); // true

分組 分支條件

正則表達式可以用 " ()  " 來進行分組,具有分組的正則表達式除了正則表達式整體會匹配子字符串外,分組中的正則表達式片段也會匹配字符串。

分組按照嵌套關系和前后關系,每個分組會分配得到一個數字組號,在一些場景中可以用組號來使用分組。

在 replace、match、exec函數中,分組都能體現不同的功能。

replace函數中,第二個參數里邊可以用 $+數字組號來指代第幾個分組的內容,如:

" the best language in the world is java ".replace(/(java)/,"$1script"); // " the best language in the world is javascript "
"/static/app1/js/index.js".replace(/(\/\w+)\.js/,"$1-v0.0.1.js"); //"/static/app1/js/index-v0.0.1.js"    (\/\w+)分組匹配的就是 /index ,

在第二個參數中為其添加上版本號

match函數中,當正則表達式有全局屬性時,會捕獲所有滿足正則表達式的子字符串

"abchellodefhellog".match(/h(ell)o/g); //["hello", "hello"]

但是當正則表達式沒有全局屬性,且正則表達式中有分組的時候,match函數只會返回整個正則表達式匹配的第一個結果,同時會將分組匹配到的字符串也放入結果數組中:

"abchellodefhellog".match(/h(ell)o/); //["hello", "ell"]
// 我們可以用match函數來分解url,獲取協議、host、path、查詢字符串等信息
"http://www.baidu.com/test?t=5".match(/^((\w+):\/\/([\w\.]+))\/([^?]+)\&;(\S+)$/);
// ["http://www.baidu.com/test?t=5", "http://www.baidu.com", "http", "www.baidu.com", "test", "t=5"]

exec函數在正則表達式中有分組的情況下,表現和match函數很像,只是無論正則表達式是否有全局屬性,exec函數都只返回一個結果,并捕獲分組的結果

/h(ell)o/g.exec("abchellodefhellog"); //["hello", "ell"]

當正則表達式需要匹配幾種類型的結果時,可以用到分支條件,例如

"asdasd hi asdad hello asdasd".replace(/hi|hello/,"nihao"); //"asdasd nihao asdad hello asdasd"
"asdasd hi asdad hello asdasd".split(/hi|hello/); //["asdasd ", " asdad ", " asdasd"]

 注意,分支條件影響它兩邊的所有內容, 比如 hi|hello  匹配的是hi或者hello,而不是 hiello 或者 hhello

分組中的分支條件不會影響分組外的內容

"abc acd bbc bcd ".match(/(a|b)bc/g); //["abc", "bbc"]

后向引用

正則表達式的分組可以在其后邊的語句中通過  \+數字組號來引用

比如

// 匹配重復的單詞
/(\b[a-zA-Z]+\b)\s+\1/.exec(" asd sf hello hello asd"); //["hello hello", "hello"]

斷言

 (?:exp) , 用此方式定義的分組,正則表達式會匹配分組中的內容,但是不再給此分組分配組號,此分組在replace、match等函數中的作用也會消失,效果如下:

/(hello)\sworld/.exec("asdadasd hello world asdasd") // ["hello world", "hello"],正常捕獲結果字符串和分組字符串
/(?:hello)\sworld/.exec("asdadasd hello world asdasd") // ["hello world"]
"/static/app1/js/index.js".replace(/(\/\w+)\.js/,"$1-v0.0.1.js"); //"/static/app1/js/index-v0.0.1.js"
"/static/app1/js/index.js".replace(/(?:\/\w+)\.js/,"$1-v0.0.1.js"); //"/static/app1/js$1-v0.0.1.js"

(?=exp) 這個分組用在正則表達式的后面,用來捕獲exp前面的字符,分組中的內容不會被捕獲,也不分配組號

/hello\s(?=world)/.exec("asdadasd hello world asdasd") // ["hello "] 

(?!exp)  和前面的斷言相反,用在正則表達式的后面,捕獲后面不是exp的字符,同樣不捕獲分組的內容,也不分配組號

/hello\s(?!world)/.exec("asdadasd hello world asdasd") //null 

處理選項

javascript中正則表達式支持的正則表達式有三個,g、i、m,分別代表全局匹配、忽略大小寫、多行模式。三種屬性可以自由組合共存。

// 全局匹配 g 
"abchelloasdasdhelloasd".match(/hello/); //["hello"]
"abchelloasdasdhelloasd".match(/hello/g); //["hello","hello"]
//忽略大小寫 i
"abchelloasdasdHelloasd".match(/hello/g); //["hello"]
"abchelloasdasdHelloasd".match(/hello/gi); //["hello","Hello"]

在默認的模式下,元字符 ^ 和 $ 分別匹配字符串的開頭和結尾處,模式 m 改變了這倆元字符的定義,讓他們匹配一行的開頭和結尾

"aadasd\nbasdc".match(/^[a-z]+$/g); //null 字符串^和$之間有換行符,匹配不上 [a-z]+ ,故返回null
"aadasd\nbasdc".match(/^[a-z]+$/gm); // ["aadasd", "basdc"] ,改變^$的含義,讓其匹配一行的開頭和末尾,可以得到兩行的結果

總結

以上所述是小編給大家介紹的Javascript中正則表達式的使用及基本語法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

您可能感興趣的文章:
  • 正則表達式基本語法及表單驗證操作詳解【基于JS】
  • JS正則表達式一條龍講解(從原理和語法到JS正則)
  • 詳解js正則表達式語法介紹
  • 老生常談JavaScript 正則表達式語法
  • JavaScript正則表達式上之基本語法(推薦)
  • javascript正則表達式定義(語法)總結
  • js正則表達式基本語法(精粹)
  • js 玩轉正則表達式之語法高亮
  • 正則表達式語法規則及在Javascript和C#中的使用方法
  • javascript中正則表達式語法詳解

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

巨人網絡通訊聲明:本文標題《Javascript中正則表達式的使用及基本語法》,本文關鍵詞  Javascript,中,正則,表達式,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Javascript中正則表達式的使用及基本語法》相關的同類信息!
  • 本頁收集關于Javascript中正則表達式的使用及基本語法的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    蜜桃久久久久久| 欧美精品 国产精品| 欧美一级生活片| 一区二区三区中文字幕在线观看| 青青草国产精品亚洲专区无| av亚洲产国偷v产偷v自拍| 777久久久精品| 日韩1区2区日韩1区2区| 91九色最新地址| 亚洲一区二区三区四区在线观看 | 亚洲欧洲国产专区| 91小视频免费观看| 亚洲伦理在线精品| 91美女视频网站| 亚洲高清在线精品| 欧美日本一区二区在线观看| 五月激情综合婷婷| 日韩一级二级三级| 国产在线国偷精品产拍免费yy| 日韩免费一区二区三区在线播放| 日本视频一区二区三区| 欧美xxxxxxxxx| 99久久精品免费| 亚洲最大成人综合| 欧美一区二区免费视频| 国产一区二区三区高清播放| 中文在线一区二区| 欧美日韩一区久久| 精品一区二区三区免费毛片爱| 久久亚洲私人国产精品va媚药| 成人av资源在线| 亚洲成a人片综合在线| 欧美成人video| 成人性生交大片免费看中文| 亚洲丰满少妇videoshd| 久久久欧美精品sm网站| 欧美精品久久久久久久多人混战 | 欧美精品一区二区三区蜜桃| 成人永久aaa| 美女mm1313爽爽久久久蜜臀| 国产精品美女久久久久久久| 欧美日韩一区二区三区在线看| 国产成人在线色| 国产呦萝稀缺另类资源| 亚洲v中文字幕| 一区二区理论电影在线观看| 中文字幕巨乱亚洲| 国产偷国产偷亚洲高清人白洁 | 不卡视频一二三四| 天天av天天翘天天综合网色鬼国产| av成人免费在线观看| 亚洲电影欧美电影有声小说| 一区二区三区高清| 国产欧美精品一区aⅴ影院 | 色综合久久中文字幕综合网| 91在线你懂得| eeuss影院一区二区三区| 国产精华液一区二区三区| 午夜电影久久久| 麻豆精品久久久| 激情五月婷婷综合网| 久久精品国产久精国产爱| 久久国产人妖系列| zzijzzij亚洲日本少妇熟睡| 色婷婷一区二区| 精品入口麻豆88视频| 精品国产一区久久| 欧美一区二区大片| 精品国产百合女同互慰| 国产女同互慰高潮91漫画| 一区免费观看视频| 性欧美大战久久久久久久久| 老司机精品视频导航| 成人影视亚洲图片在线| 日韩欧美一区二区在线视频| www国产精品av| 国产精品乱人伦一区二区| 亚洲永久免费av| 久久97超碰国产精品超碰| 成人av免费在线播放| 欧美一区二区在线观看| 亚洲人成网站色在线观看| 国内成人精品2018免费看| 在线观看日韩精品| 日韩欧美国产一区在线观看| 国产精品美女一区二区| 全国精品久久少妇| 成人av在线资源网站| 日韩亚洲欧美一区二区三区| 亚洲美女电影在线| 国产精品亚洲一区二区三区妖精| 欧美理论电影在线| 一区二区三区不卡在线观看| 国产一区福利在线| 日韩女优制服丝袜电影| 视频一区二区三区中文字幕| 91最新地址在线播放| 欧美激情一区在线观看| 久久精品国产99久久6| 日韩视频在线你懂得| 极品少妇一区二区| 国产三级一区二区| 国产a视频精品免费观看| 久久精品在线观看| 成人免费黄色在线| 国产精品日韩成人| 91在线视频播放| 中文字幕日本乱码精品影院| 国产一区二区美女诱惑| xfplay精品久久| 国产一区二区三区四区在线观看 | 在线观看视频91| 免费在线观看视频一区| 久久久精品中文字幕麻豆发布| 国产suv精品一区二区6| 亚洲美女精品一区| 欧美一区二区三区免费| 国产传媒久久文化传媒| 国产亚洲欧美在线| 欧美色涩在线第一页| 国产精品自拍一区| 一区二区三区小说| 欧美高清性hdvideosex| 久久不见久久见免费视频7 | 91蝌蚪国产九色| 老司机午夜精品| 欧美国产精品专区| 欧美日韩国产大片| heyzo一本久久综合| 国产一区在线看| 亚洲综合在线观看视频| 欧美变态凌虐bdsm| 色欧美日韩亚洲| 国产成人免费在线观看| 亚洲成a人片在线不卡一二三区| 亚洲欧美在线观看| 1区2区3区精品视频| 欧美国产一区视频在线观看| 日韩欧美国产综合一区| 在线观看亚洲精品| 91免费观看在线| 99久久精品99国产精品| 岛国av在线一区| 国产乱妇无码大片在线观看| 美女国产一区二区三区| 石原莉奈在线亚洲二区| 性久久久久久久久| 亚洲妇女屁股眼交7| 亚洲精品日韩综合观看成人91| 日本一区二区三区免费乱视频| 欧美刺激午夜性久久久久久久| 欧美一三区三区四区免费在线看 | 国产91精品一区二区麻豆亚洲| 日韩精品电影在线观看| 日本亚洲欧美天堂免费| 精品一区二区三区香蕉蜜桃| 国产一区二区三区四区五区美女| 日本一区中文字幕 | 亚洲欧洲精品成人久久奇米网| 欧美成人精品福利| 欧美哺乳videos| 久久日韩粉嫩一区二区三区| 日韩欧美亚洲另类制服综合在线 | 亚洲国产一区在线观看| 免费欧美在线视频| 国产一区二区三区国产| 国产69精品久久久久777| 欧美视频一二三区| 亚洲精品一区二区三区99| 亚洲欧美另类图片小说| 青青草国产成人99久久| 国产精品1区2区3区| 成人动漫av在线| 欧美精品精品一区| 中文字幕视频一区| 亚洲大尺度视频在线观看| 成人av在线一区二区三区| 欧美影视一区二区三区| 久久日韩粉嫩一区二区三区| 亚洲美女免费在线| 国产一区激情在线| 91精品国产色综合久久不卡蜜臀 | 欧美另类一区二区三区| 国产欧美一区二区精品性| 日本亚洲一区二区| 欧美日韩中文另类| 一区在线观看视频| 91在线国产福利| 精品乱码亚洲一区二区不卡| 亚洲欧美一区二区三区国产精品 | 日韩视频在线观看一区二区| 亚洲一二三专区| 色999日韩国产欧美一区二区| 久久久久久一二三区| 久久国产人妖系列| 欧美亚洲图片小说| 亚洲综合精品自拍| 欧美人xxxx| 国内成人免费视频| 国产午夜久久久久|