JavaScript中正則表達式的作用有哪些

JavaScript中正則表達式的作用有哪些?針對這個問題,這篇文章詳細介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

公司主營業(yè)務(wù):網(wǎng)站建設(shè)、做網(wǎng)站、移動網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。成都創(chuàng)新互聯(lián)是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。成都創(chuàng)新互聯(lián)推出古雷港免費做網(wǎng)站回饋大家。

閱讀目錄

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

  • 正則表達式中的特殊字符

  • \ (反斜杠)

  • ^

  • $

  • *,  +,  .(小數(shù)點)

  • ? (問號)

  • (x)

  • (?:x)

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

  • {n}, {n,m}:

  • [xyz], [^xyz]

  • 其他

  • 正則表達式標志

  • 正則表達式使用

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

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

兩種方法,一種是直接寫,由包含在斜杠之間的模式組成;另一種是調(diào)用RegExp對象的構(gòu)造函數(shù)。

兩種方法的創(chuàng)建代碼如下:

// 直接創(chuàng)建
const regex1 = /ab+c/;
const regex2 = /^[a-zA-Z]+[0-9]*\W?_$/gi;
// 調(diào)用構(gòu)造函數(shù)
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');

可以看出,調(diào)用RegExp構(gòu)造函數(shù)創(chuàng)建正則表達式時,第一個參數(shù)可以是字符串,也可以是直接創(chuàng)建的正則表達式。

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

例如:

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.將其后的特殊字符轉(zhuǎn)譯為字面量;

注意:在使用RegExp構(gòu)造函數(shù)時要將\轉(zhuǎn)譯,因為\在字符串里也是轉(zhuǎn)譯字符

^

1.匹配輸入的開始;

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

例子:

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

$

匹配輸入的結(jié)束

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

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

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

.:

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

? (問號)

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

2.如果緊跟在任何量詞 * + ? {} 的后面,將會使量詞變?yōu)榉秦澙返模ㄆヅ浔M量少的字符),和缺省使用的貪婪模式正好相反;

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 是用在正則表達式的匹配環(huán)節(jié),在正則表達式的替換環(huán)節(jié),則要使用像 $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

這兩種匹配的結(jié)果都不包含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}:匹配了前面一個字符剛好發(fā)生了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:匹配一個詞的邊界。一個匹配的詞的邊界并不包含在匹配的內(nèi)容中。換句話說,一個匹配的詞的邊界的內(nèi)容的長度是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:匹配一個數(shù)字,等價于[0-9];

\D:匹配一個非數(shù)字字符,等價于[^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:匹配一個單字字符(字母、數(shù)字或者下劃線),等價于[A-Za-z0-9_];

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

正則表達式標志

g:全局搜索;

i:不區(qū)分大小寫;

m:多行搜索;

正則表達式使用

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

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

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

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

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

其中,當replace有function時,參數(shù)說明如下:

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

關(guān)于JavaScript中正則表達式的作用有哪些問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識。

網(wǎng)站題目:JavaScript中正則表達式的作用有哪些
分享網(wǎng)址:http://muchs.cn/article0/ipgiio.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供建站公司、自適應(yīng)網(wǎng)站營銷型網(wǎng)站建設(shè)、網(wǎng)站改版、動態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作