亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > 深入淺析js中的正則表達式

深入淺析js中的正則表達式

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

閱讀目錄

  • 正則表達式的創建
  • 正則表達式中的特殊字符
  • \ (反斜杠)
  • ^
  • $
  • *,  +,  .(小數點)
  • ? (問號)
  • (x)
  • (?:x)
  • x(?=y), x(?!y), x|y
  • {n}, {n,m}:
  • [xyz], [^xyz]
  • 其他
  • 正則表達式標志
  • 正則表達式使用

很多時候多會被正則表達式搞的暈頭轉向,最近抽出時間對正則表達式進行了系統的學習,整理如下:

正則表達式的創建

兩種方法,一種是直接寫,由包含在斜杠之間的模式組成;另一種是調用RegExp對象的構造函數。

兩種方法的創建代碼如下:

// 直接創建
const regex1 = /ab+c/;
const regex2 = /^[a-zA-Z]+[0-9]*\W?_$/gi;
// 調用構造函數
const regex3 = new RegExp('ab+c');
const regex4 = new RegExp(/^[a-zA-Z]+[0-9]*\W?_$/, "gi");
const regex5 = new RegExp('^[a-zA-Z]+[0-9]*\W?_$', 'gi');

可以看出,調用RegExp構造函數創建正則表達式時,第一個參數可以是字符串,也可以是直接創建的正則表達式。

需要注意的是:RegExp實例繼承的toLocaleString()和toString)()方法都會返回正則表達式的字面量,與創建正則表達式的方式無關

例如:

const ncname = '[a-zA-Z_][\\w\\-\\.]*';
const qnameCapture = '((?:' + ncname + '\\:)?' + ncname + ')';
const startTagOpen = new RegExp('^' + qnameCapture);
startTagOpen.toString();    // '/^((?:[a-zA-Z_][\w\-\.]*\:)?[a-zA-Z_][\w\-\.]*)/' 

正則表達式中的特殊字符

\ (反斜杠)

1.在非特殊字符前加反斜杠表示下一個字符是特殊的;

2.將其后的特殊字符轉譯為字面量;

注意:在使用RegExp構造函數時要將\轉譯,因為\在字符串里也是轉譯字符

^

1.匹配輸入的開始;

2.在[]中的第一位時表示反向字符集;

例子:

/^A/.exec('an A')    // null
/^A/.exec('An E')    // ["A", index: 0, input: "An E"]

$

匹配輸入的結束

/t$/.exec('eater')    // null
/t$/.exec('eat')     // ["t", index: 2, input: "eat"]
*, +, .(小數點) 

*:匹配前一個表達式0次或多次。等價于 {0,};

+:匹配前面一個表達式1次或者多次。等價于 {1,};

.:

匹配除換行符之外的任何單個字符;

? (問號)

1.匹配前面一個表達式0次或者1次。等價于 {0,1};

2.如果緊跟在任何量詞 * + ? {} 的后面,將會使量詞變為非貪婪的(匹配盡量少的字符),和缺省使用的貪婪模式正好相反;

3.運用于先行斷言

例子:

/\d+/.exec('123abc')       // ["123", index: 0, input: "123abc"]
/\d+?/.exec('123abc')      // ["1", index: 0, input: "123abc"]

(x)

匹配 'x' 并且記住匹配項,括號表示捕獲括號;

例子:

/(foo) (bar) \1 \2/.test('bar foo bar foo');  // false
/(bar) (foo) \1 \2/.test('bar foo bar foo');  // true
/(bar) (foo) \1 \2/.test('bar foo');      // false
/(bar) (foo) \1 \2/.test('bar foo foo bar');  // false
/(bar) (foo) \2 \1/.test('bar foo foo bar');  // true
'bar foo bar foo'.replace( /(bar) (foo)/, '$2 $1' );  // "foo bar bar foo"

模式 /(foo) (bar) \1 \2/ 中的 '(foo)' 和 '(bar)' 匹配并記住字符串 "foo bar foo bar" 中前兩個單詞。模式中的 \1 和 \2 匹配字符串的后兩個單詞。

注意:\1、\2、\n 是用在正則表達式的匹配環節,在正則表達式的替換環節,則要使用像 $1、$2、$n 這樣的語法。例如,'bar foo'.replace( /(...) (...)/, '$2 $1' )。

(?:x)

匹配 'x' 但是不記住匹配項,這種叫作非捕獲括號;

例子:

'foo'.match(/foo{1,2}/)        // ["foo", index: 0, input: "foo"]
'foo'.match(/(?:foo){1,2}/)      // ["foo", index: 0, input: "foo"]
'foofoo'.match(/(?:foo){1,2}/)     // ["foofoo", index: 0, input: "foofoo"]
'foofoo'.match(/foo{1,2}/)       // ["foo", index: 0, input: "foofoo"]

使用場景:示例表達式 /(?:foo){1,2}/。如果表達式是 /foo{1,2}/,{1,2}將只對 ‘foo' 的最后一個字符 'o‘ 生效。如果使用非捕獲括號,則{1,2}會匹配整個 ‘foo' 單詞。

x(?=y), x(?!y), x|y

x(?=y):匹配'x'僅僅當'x'后面跟著'y';

x(?!y):匹配'x'僅僅當'x'后面不跟著'y';

x|y: 匹配x或y

這兩種匹配的結果都不包含y

例子:

'JackSprat'.match(/Jack(?=Sprat)/)      // ["Jack", index: 0, input: "JackSprat"]
'JackWprat'.match(/Jack(?=Sprat)/)      // null
'JackWprat'.match(/Jack(?=Sprat|Wprat)/)  // ["Jack", index: 0, input: "JackWprat"]
/\d+(?!\.)/.exec("3.141")    // ["141", index: 2, input: "3.141"]

{n}, {n,m}:

{n}:匹配了前面一個字符剛好發生了n次;

{n,m}:匹配前面的字符至少n次,最多m次。如果 n 或者 m 的值是0, 這個值被忽略;

例子:

  /a{2}/.exec('candy')     // null
  /a{2}/.exec('caandy')    // ["aa", index: 1, input: "caandy"]
  /a{2}/.exec('caaandy')    // ["aa", index: 1, input: "caaandy"]
  /a{1,3}/.exec('candy')    // ["a", index: 1, input: "candy"]
  /a{1,3}/.exec('caandy')   // ["aa", index: 1, input: "caandy"]
  /a{1,3}/.exec('caaandy')   // ["aaa", index: 1, input: "caaandy"]
  /a{1,3}/.exec('caaaandy')  // ["aaa", index: 1, input: "caaaandy"]  

[xyz], [^xyz]

[xyz]:一個字符集合。匹配方括號的中任意字符;

[^xyz]:一個反向字符集。匹配任何沒有包含在方括號中的字符;

這兩種匹配都可以使用破折號(-)來指定一個字符范圍,特殊符號在字符集中沒有了特殊意義。

例:

function escapeRegExp(string){
  return string.replace(/([.*+?^=!:${}()|[\]\/\\])/g, "\\$"); 
  //$表示整個被匹配的字符串
}

例子中的.*+?^=!:${}()都表示字面量,并沒有特殊意義。

其他

\b:匹配一個詞的邊界。一個匹配的詞的邊界并不包含在匹配的內容中。換句話說,一個匹配的詞的邊界的內容的長度是0;

\B: 匹配一個非單詞邊界;

例子:

  /\bm/.exec('moon')             // ["m", index: 0, input: "moon"]
  /\bm/.exec('san moon')           // ["m", index: 4, input: "san moon"]
  /oo\b/.exec('moon')             // null
  /\B../.exec('noonday')          // ["oo", index: 1, input: "noonday"]
  /y\B../.exec('possibly yesterday')    // /y\B../.exec('possibly yesterday')

\d:匹配一個數字,等價于[0-9];

\D:匹配一個非數字字符,等價于[^0-9];

\f:匹配一個換頁符 (U+000C);

\n:匹配一個換行符 (U+000A);

\r:匹配一個回車符 (U+000D);

\s:匹配一個空白字符,包括空格、制表符、換頁符和換行符,等價于[ \f\n\r\t\v\u00a0\u1680\u180e\u2000-\u200a\u2028\u2029\u202f\u205f\u3000\ufeff];

\S:匹配一個非空白字符,等價于[^ \f\n\r\t\v\u00a0\u1680\u180e\u2000-\u200a\u2028\u2029\u202f\u205f\u3000\ufeff];

\w:匹配一個單字字符(字母、數字或者下劃線),等價于[A-Za-z0-9_];

\W:匹配一個非單字字符,等價于[^A-Za-z0-9_];

正則表達式標志

g:全局搜索;

i:不區分大小寫;

m:多行搜索;

正則表達式使用

RegExp有exec()和test()方法;

exec匹配的結果為:匹配結果、捕獲結果,index和input。

test匹配的結果為true或false,效率比exec要高。

String有match(),replace(),search(),split()方法;

match匹配的結果同RegExp的exec,replace根據正則表達式替換,search查找所以位置,split根據正則表達式分割字符串。

其中,當replace有function時,參數說明如下:

* 匹配項
* 記憶項(括號里面的項)
* ...
* 匹配的index
* input輸入項

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

您可能感興趣的文章:
  • JS正則表達式一條龍講解(從原理和語法到JS正則)
  • JS中正則表達式全局匹配模式 /g用法詳解
  • JS中使用正則表達式g模式和非g模式的區別
  • js中string之正則表達式replace方法詳解
  • 一個容易犯錯的js手機號碼驗證正則表達式(推薦)
  • js中使用正則表達式查找字母和數字的方法
  • JS正則表達式驗證密碼格式的集中情況總結
  • JS 密碼強度校驗的正則表達式(簡單且好用)
  • JavaScript正則表達式替換字符串中圖片地址(img src)的方法

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

巨人網絡通訊聲明:本文標題《深入淺析js中的正則表達式》,本文關鍵詞  深入,淺析,中的,正則,表達式,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《深入淺析js中的正則表達式》相關的同類信息!
  • 本頁收集關于深入淺析js中的正則表達式的相關信息資訊供網民參考!
  • 推薦文章
    成人免费高清视频| 天天色色色| 日韩av东京社区男人的天堂| 亚洲女人国产香蕉久久精品 | 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 麻豆网站在线免费观看| 亚洲天堂在线播放| 日本免费区| 天天色色色| 可以在线看黄的网站| 国产一区二区福利久久| 国产网站在线| 国产原创视频在线| 一级女性大黄生活片免费| 免费国产在线观看不卡| 亚洲天堂免费观看| 999久久狠狠免费精品| 九九免费精品视频| 日韩av东京社区男人的天堂| 天天做日日干| a级毛片免费观看网站| 尤物视频网站在线观看| 欧美a免费| 99色精品| 九九精品在线播放| 日韩av东京社区男人的天堂| 精品国产一区二区三区免费| 美女免费精品视频在线观看| 久久99这里只有精品国产| 午夜欧美福利| 国产福利免费观看| 亚洲精品中文一区不卡| 尤物视频网站在线观看| 黄视频网站在线看| 亚欧视频在线| 高清一级片| 夜夜操天天爽| 国产亚洲免费观看| 成人在激情在线视频| 99久久精品国产片| 国产伦精品一区三区视频| 欧美大片毛片aaa免费看| 欧美大片毛片aaa免费看| 欧美激情一区二区三区中文字幕| 日韩在线观看视频网站| 午夜欧美福利| 国产国语对白一级毛片| 成人免费一级毛片在线播放视频| 韩国毛片基地| 欧美a免费| 可以在线看黄的网站| 精品国产三级a∨在线观看| 国产精品1024永久免费视频| 国产国语对白一级毛片| 欧美激情一区二区三区在线 | 精品视频在线观看视频免费视频| 四虎影视久久久| 在线观看导航| 天天做人人爱夜夜爽2020| 免费毛片播放| 国产a视频| 国产网站在线| 成人在激情在线视频| 天天做人人爱夜夜爽2020| 午夜在线亚洲| 成人免费观看的视频黄页| 精品视频在线观看视频免费视频| 午夜激情视频在线播放| 国产一区免费观看| 久久精品免视看国产明星| 国产91精品一区| 欧美激情一区二区三区中文字幕| 91麻豆精品国产自产在线| 精品在线免费播放| 一a一级片| 91麻豆精品国产自产在线| 国产激情一区二区三区| 欧美激情在线精品video| 天天做日日爱| 欧美1卡一卡二卡三新区| 国产91精品一区| 韩国三级香港三级日本三级la| 国产韩国精品一区二区三区| 亚洲爆爽| 国产麻豆精品hdvideoss| 国产美女在线观看| 日本乱中文字幕系列| 91麻豆精品国产高清在线| 高清一级做a爱过程不卡视频| 99久久精品国产国产毛片| 成人高清护士在线播放| 国产91素人搭讪系列天堂| 一级女性全黄生活片免费| 精品美女| 亚洲天堂在线播放| 欧美a级片视频| 国产欧美精品| 黄色免费网站在线| 可以免费看污视频的网站| 国产激情一区二区三区| 欧美大片毛片aaa免费看| 亚洲天堂免费观看| 久久国产影院| 国产91视频网| 国产视频网站在线观看| 色综合久久天天综线观看| 日韩专区一区| 久久国产一区二区| 国产一级强片在线观看| 亚洲精品影院久久久久久| 久久国产精品自由自在| 美女免费黄网站| 国产不卡福利| 国产一区国产二区国产三区| a级毛片免费观看网站| 国产视频网站在线观看| 精品视频在线看| 黄色免费网站在线| 成人a级高清视频在线观看| 欧美a级片视频| 欧美激情一区二区三区中文字幕| 亚洲天堂在线播放| 欧美爱爱动态| 久草免费在线色站| 亚洲 国产精品 日韩| 亚洲 欧美 91| 欧美电影免费看大全| 亚洲天堂在线播放| 精品国产香蕉在线播出| 国产91素人搭讪系列天堂| 999精品在线| 欧美a免费| 91麻豆精品国产综合久久久| 午夜激情视频在线播放| 欧美国产日韩在线| 免费国产在线观看不卡| 精品视频在线看| 国产麻豆精品免费密入口| 国产亚洲精品aaa大片| 韩国毛片基地| 韩国三级视频网站| 成人a大片高清在线观看| 黄色短视频网站| 国产一区二区福利久久| 青青久久精品| 免费的黄色小视频| 国产一区免费观看| 成人免费网站视频ww| 九九久久国产精品| 黄视频网站免费观看| 精品久久久久久中文字幕2017| 国产成人精品综合在线| 欧美爱爱动态| 中文字幕一区二区三区精彩视频 | 国产高清在线精品一区二区| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 九九久久国产精品| 韩国三级视频在线观看| 日韩中文字幕在线亚洲一区| 日韩在线观看视频网站| 日韩中文字幕在线播放| 91麻豆tv| 欧美国产日韩久久久| 一级毛片视频在线观看| 国产高清在线精品一区二区| 沈樵在线观看福利| 精品美女| 亚洲第一页乱| 日本特黄一级| 日韩中文字幕在线播放| 国产视频一区在线| 欧美另类videosbestsex高清| 四虎久久精品国产| 高清一级片| 成人高清护士在线播放| 亚洲精品影院久久久久久| 国产高清视频免费| 一级女性大黄生活片免费| 高清一级片| 一级女性全黄生活片免费| 91麻豆tv| 亚洲爆爽| 日韩avdvd| 国产成a人片在线观看视频| 精品视频在线看| 超级乱淫黄漫画免费| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 一级毛片视频在线观看| 国产伦精品一区三区视频| 香蕉视频久久| 天天做日日干| 日韩男人天堂| 久久久久久久免费视频| 免费毛片播放| 毛片电影网| 二级特黄绝大片免费视频大片| 日韩免费在线观看视频| 精品国产亚洲人成在线| 日韩在线观看视频黄| 日韩免费在线观看视频|