日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

js 正则学习小记之匹配字符串

發布時間:2025/4/16 编程问答 52 豆豆
生活随笔 收集整理的這篇文章主要介紹了 js 正则学习小记之匹配字符串 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
原文:js 正則學習小記之匹配字符串

今天看了第5章幾個例子,有點收獲,記錄下來當作回顧也當作分享。

關于匹配字符串問題,有很多種類型,今天討論 js 代碼里的字符串匹配。(因為我想學完之后寫個語法高亮練手,所以用js代碼當作例子)
?var str1 = "我是字符串1哦,快把我取走", str2 = "我是字符串2哦,快把我取走";?
比如這樣一個字符串,匹配起來很簡單 /"[^"]*"/g 即可。

PS: 白色截圖是 chrome 34 控制臺中運行的結果,深灰色是 sublime text 結果。

很容易就取到內容了,可是親,你有沒有想過,js字符串里允許轉義。
?var str1 = "我是字符串1哦,\"快把我取走\"", str2 = "我是字符串2哦,\"快把我取走\"";?

這不是我們想要的結果,所以我們要處理下轉義問題。
轉義的規則是 \ 后面跟著一個字符,所以我們用 \\. 去匹配它,就有了這樣的正則 /"(?:\\.|[^"])*"/g

可能對于正則不熟悉的朋友,一下子從 /"[^"]*"/g 變到 /"(?:\\.|[^"])*"/g 后理解不了,我簡單說明下。
(?:) 是非捕獲組,就是不會把內容抓取保存到內存里的。
\\. 用于匹配 \" \' \a 之類的轉義字符,匹配成功的話消耗2個字符。
[^"] 匹配除了 " 以外的所有字符,匹配成功的話消耗1個字符。
所以這個表達式的意思是,先匹配 \. 這樣轉義,如果成功會消耗掉正確的轉義,如果不成功就用?[^"]?匹配。

消耗掉正確的轉義的意思是,比如 "aa\\aa\"aa\ufffaa" 都會被正常匹配,因為這些都在正常的轉義。
形如 "aa\\aa\"aa\ufff\\"aa" 這里的 \\" 其中 \\ 會被匹配,而 " 既不滿足 \\. 也不滿足 [^"]
所以這個匹配結果會是 "aa\\aa\"aa\ufff\\" 后面的 aa" 無法匹配到。

所以現在我們得到了比較強力的正則,可以有效的匹配 js 代碼中的字符串了。

騷等,好像還有哪里不對。
js 字符串允許折行,形如這樣:

var str = "大家好\ 我是js";

但是這樣的字符串用剛才的正則能匹配么?答案是能。
因為 \ 不能被 \\. 匹配,但是可以被 [^"] 匹配到,\ 后面一個字符是?\r,?\n?或?\r\n (具體是什么換行符要看系統了) 都能被 [^"] 匹配到,所以我們無意間寫了個強力的表達式。

現在剩下最后一個問題了,就是 ' 的匹配。
我們修改下表達式 /"(?:\\.|[^"])*"|'(?:\\.|[^'])*'/g 就好了。

來測試一下:

var str1 = "我是字符串1哦,\ \"快把我取走\"", str2 = '我是字符串2哦,\ \'快把我取走\'';

匹配成功。


好了,這些就是今天的分享了,明天見。

?

總結

以上是生活随笔為你收集整理的js 正则学习小记之匹配字符串的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。