JavaScript 正則表達(dá)式

描述字符模式的對(duì)象

在線測(cè)試 regexr
正則常用參考

修飾符

  • /foo/i ignore case: 忽略匹配模式的字母大小寫
  • /foo/g global search: 全局匹配
  • /foo/m multiline: 轉(zhuǎn)換為多行魄幕,分別進(jìn)行匹配

特殊符號(hào)

  • /./ 通配符: 匹配換行符以外的所有字符
  • /png|gif|jpg/ 選擇符: 或者

Note:
匹配 . 本身需要轉(zhuǎn)義 /\./
/a|ab/g abc => a


匹配可見(jiàn)字符,只用來(lái)指定匹配發(fā)生的位置

TypeScript 
CoffeeScript 
Scripting 
ActionScriptEditor
  • /^Script/m : 匹配以 Script 開(kāi)頭的字符呛哟。Scripting
  • /Script$/mg : 匹配以 Script 結(jié)束的字符荔泳。TypeScriptCoffeeScript
  • /Script\b/mg :字邊界蝉娜。匹配以 Script 結(jié)尾的單詞 TypeScript馏予,CoffeeScript
  • /Script\B/mg: 非字邊界乐尊。匹配單詞中含有 Script 的單詞雳刺,但單詞不能以 Script 結(jié)尾劫灶。ScriptingActionScriptEditor

Note:
以上4例中匹配的結(jié)果均為 Script掖桦,而非某個(gè)完整單詞
[\b] 代表退格符

斷言

  • (?=foo) 零寬正向先行斷言:之后的字符要與其匹配本昏,但不包含這些字符

    eg:
    /\d+(?=px)/ 只匹配后面是px的數(shù)字,但匹配結(jié)果并不包含 px

    3px 6em 12px => 3 12

  • (?!foo) 零寬反向先行斷言枪汪,之后的字符不與其匹配
    eg1: /\d+(?!px)(?!\d)/只匹配不是以 px 結(jié)尾的數(shù)字
    3px 6em 12px => 6
    eg2: /\d+(?!px)/
    3px 6em 12px => 6 1


字符集 []

匹配字符集內(nèi)的某一個(gè)字符

字符集中的特殊符號(hào)

  • /[^abc]/: 否定涌穆,不包含字符集中的任何一個(gè)
  • /[a-c]/: 表示范圍。即 /[abc]/料饥。

Note:
字符集中的 - 只要有一側(cè)沒(méi)有字符就不用轉(zhuǎn)義。eg:/[-2]/ 匹配 -2
字符集中的 . 不用轉(zhuǎn)義
字符集中的 \b 代表退格符

轉(zhuǎn)義字符集

  • \d: digital: 匹配數(shù)字朱监。[0-9]
  • \D: 匹配非數(shù)字岸啡。[^0-9]
  • \w: word: 匹配字母、數(shù)字和下劃線 _(ASCII單詞)赫编。[a-zA-Z0-9_]
  • \W: 匹配除字母巡蘸、數(shù)字和下劃線以外的字符(非ASCII單詞)奋隶。 [^a-zA-Z0-9_]
  • \s: space: 空,制表符悦荒,以及其他 unicode 空白符唯欣,tab\t,換行符\n 搬味,回車符 \r境氢。 [ \t\n\r]
  • \S: 非 Unicode 空白符

重復(fù)

*: 0個(gè)及以上
+: 1個(gè)及以上
?: 1個(gè)及以下
{2}: 2個(gè)
{2,}: 2個(gè)以上
{2,4} 2到4個(gè)

非貪婪重復(fù)

正則的重復(fù)規(guī)則默認(rèn)匹配盡量多的字符,使用 碰纬?來(lái)匹配盡可能少的字符

/a+?/ aaa => 第一個(gè) a
/a+?/g aaa => 全部3個(gè) a
/a+?b/ aaaab => aaaab 與貪婪模式一致萍聊,正則總是尋找字符串中第一個(gè)可匹配的字符進(jìn)行匹配[1]


群組 ()

方便使用重復(fù)符號(hào) /Java(Script)?/: Java 或者 JavaScript

群組的引用

\ 加上群組的序數(shù)

eg: /<h(\d)>.*<\/h\1>/ 匹配一個(gè)閉合標(biāo)簽,\1代表前面的群組 (\d) 匹配到的數(shù)字悦析。

+ <h1>h1</h1>   ?
+ <h2>h2</h2>   ?
- <h3>xxxx</h4> ?

$ 加上數(shù)字可以取得正則表達(dá)式匹配結(jié)構(gòu)中的第幾個(gè)群組寿桨,例如 $1/Java(Script)/ 中即為 Script,用法參照下方的 string.replace 方法

$& 可以獲取匹配的整個(gè)項(xiàng)目强戴,既上面的 JavaScript

?:不為群組添加引用 (?:Script) 不存儲(chǔ)群組的匹配值亭螟,既使用 $1 不能得到 Script,只能得到字符串形式的 '$1'


字符串中與正則相關(guān)的實(shí)例方法

  • string.match(regExp) [array/null]

    • 返回一個(gè)由匹配結(jié)果組成的數(shù)組骑歹,沒(méi)有匹配項(xiàng)則返回 null预烙。
    • 如果有修飾符 g 則數(shù)組中包含所有匹配結(jié)果;如果沒(méi)有修飾符 g陵刹,返回的數(shù)組第一項(xiàng)是匹配結(jié)果默伍,而后數(shù)組的第n項(xiàng)是 $n。
    • 數(shù)組后添加的 index 屬性是字符串中匹配的起始位置衰琐。
    • 數(shù)組后添加的 input 的屬性是原始的字符串也糊。
  • string.search(regExp) [number]

    • 返回匹配的起始位置,如果不存在匹配字符則返回 -1羡宙。
    • 不支持全局檢索狸剃,即會(huì)忽略修飾符 g。
    • 如果傳入的參數(shù)不是正則實(shí)例狗热,則內(nèi)部使用 RegExp 構(gòu)造函數(shù)先將參數(shù)轉(zhuǎn)化為正則實(shí)例钞馁。
  • string.replace(regExp|string, newString|function) [string] [3]

    • 第一個(gè)參數(shù)是匹配的模式,如果是字符串則使用 RegExp 構(gòu)造函數(shù)先將參數(shù)轉(zhuǎn)化為正則實(shí)例匿刮。
    • 第二個(gè)參數(shù)是替換后的字符僧凰,如果參數(shù)是函數(shù),那么函數(shù)的返回值則是替換的內(nèi)容
    • 如果用于替換后的字符中包含了未使用的引用熟丸,則將其視為原始字符處理 eg4训措。
    'jaVAscriPt'.replace(/javascript/i, 'JavaScript')
    // => JavaScript
    
    'false can use?'.replace(false, true) 
    // =>'true can use?'
    
    'iOS, windows Phone, Android'.replace(/(ios)(.*)(android)/i, '$3$2$1')
    // => 'Android, windows Phone, iOS'
    
    

'iOS, windows Phone, Android'.replace(/(ios)(.*)(android)/i, '$3$2$1$4')
// => 'Android, windows Phone, iOS$4'

'phone systems: iOS, windows Phone, Android'.replace(
/(ios)(.*)(android)/i,
function (match, $1, $2, $3, index, input) {
// match: 'iOS, windows Phone, Android'
// $1: 'iOS'
// $2: ', windows Phone, '
// $3: 'Android'
// index: 15
// input: 'phone systems: iOS, windows Phone, Android'
return 'phone systems: ' + $3 + $2 + $1
}
)
// => 'phone systems: Android, windows Phone, iOS'


- `string.split(string|regexp) [array]`   [4]
* 使用參數(shù)切分字符串,并將結(jié)果保存到數(shù)組中返回。
* 如果字符串最末是切分的標(biāo)志绩鸣,則返回的數(shù)組最后一項(xiàng)則是空字符串怀大。

``` javascript
'user=jack&id=233&city=beijing'.split('&')
// => ['user=jack', 'id=233', 'city=beijing']

'1w2Y3s4E5'.split(/[a-z]/i)
// => ['1', '2', '3', '4', '5']

'1w2Y3s4E5x'.split(/[a-z]/i)
// => ['1', '2', '3', '4', '5', '']

JavaScript 中的正則 RegExp

const pattern = /foo$/
const pattern = new RegExp("foo$")

每次使用直接量都會(huì)創(chuàng)建新的對(duì)象(eg : /foo/

實(shí)例屬性

  • [string] regexp.source 正則表達(dá)式文本,只讀

    /[^foo]/.source // => "[^foo]" 
    
  • [boolean] regexp.ignoreCase 是否帶有 i 修飾符呀闻,只讀

  • [boolean] regexp.multiline 是否帶有 m 修飾符化借,只讀

  • [boolean] regexp.global 是否含有 g 修飾符,只讀

    /foo/i.global // => false
    /baz/g.global // => true
    
  • [number] regexp.lastIndex
    同一個(gè)正則實(shí)例會(huì)存儲(chǔ)上一次匹配正確的位置捡多。為了保證匹配結(jié)果容易控制蓖康,可以每次使用新的實(shí)例來(lái)進(jìn)行匹配,或者使用字符串的實(shí)例方法局服。

    /** 全局匹配 **/
    const pattern = /\d/g
    
    pattern.lastIndex    // 0
    pattern.exec('1234') // ["1", index: 0, input: "1234"]
    
    pattern.lastIndex    // 1
    pattern.test('1234') // true
    
    pattern.lastIndex    // 2
    pattern.exec('1234') // ["3", index: 2, input: "1234"]
    
    /** 非全局匹配 **/
    

const pattern = /\d/

pattern.lastIndex // 0
pattern.exec('1234') // ["1", index: 0, input: "1234"]

pattern.lastIndex // 0
pattern.test('1234') // true

pattern.lastIndex // 0
pattern.exec('1234') // ["1", index: 0, input: "1234"]


### 實(shí)例方法

- `regexp.exec(string) [null/Array]` 
* 匹配失敗返回 `null`钓瞭,匹配成功返回一個(gè)數(shù)組。但數(shù)組總只有一項(xiàng)淫奔,既總是只返回匹配到的第一個(gè)結(jié)果山涡,修飾符 g 此處無(wú)效。
* 數(shù)組后添加的 index 屬性是字符串中匹配的起始位置唆迁。
* 數(shù)組后添加的 input 的屬性是原始的字符串鸭丛。

``` javascript
/\d/.exec('1234')
// => ['1', index: 0, input: '1234']

/\d/g.exec('a1234')
// => ['1', index: 1, input: 'a1234']
  • regexp.test(string) [boolean] regexp.exec()的簡(jiǎn)單版,只返回一個(gè)布爾值唐责。

參考

  1. 《 Javascript 權(quán)威指南(第六版)》第10章
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末鳞溉,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子鼠哥,更是在濱河造成了極大的恐慌熟菲,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件朴恳,死亡現(xiàn)場(chǎng)離奇詭異抄罕,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)于颖,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門呆贿,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人森渐,你說(shuō)我怎么就攤上這事做入。” “怎么了同衣?”我有些...
    開(kāi)封第一講書人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵竟块,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我耐齐,道長(zhǎng)浪秘,這世上最難降的妖魔是什么前弯? 我笑而不...
    開(kāi)封第一講書人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮秫逝,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘询枚。我一直安慰自己违帆,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布金蜀。 她就那樣靜靜地躺著刷后,像睡著了一般。 火紅的嫁衣襯著肌膚如雪渊抄。 梳的紋絲不亂的頭發(fā)上尝胆,一...
    開(kāi)封第一講書人閱讀 51,125評(píng)論 1 297
  • 那天,我揣著相機(jī)與錄音护桦,去河邊找鬼含衔。 笑死,一個(gè)胖子當(dāng)著我的面吹牛二庵,可吹牛的內(nèi)容都是我干的贪染。 我是一名探鬼主播,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼催享,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼杭隙!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起因妙,我...
    開(kāi)封第一講書人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤痰憎,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后攀涵,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體铣耘,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年汁果,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了涡拘。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡据德,死狀恐怖鳄乏,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情棘利,我是刑警寧澤橱野,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站善玫,受9級(jí)特大地震影響水援,放射性物質(zhì)發(fā)生泄漏密强。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一蜗元、第九天 我趴在偏房一處隱蔽的房頂上張望或渤。 院中可真熱鬧,春花似錦奕扣、人聲如沸薪鹦。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)池磁。三九已至,卻和暖如春楷兽,著一層夾襖步出監(jiān)牢的瞬間地熄,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來(lái)泰國(guó)打工芯杀, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留端考,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓揭厚,卻偏偏與公主長(zhǎng)得像跛梗,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子棋弥,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容