JavaScript中正則表達(dá)式的實際應(yīng)用詳解
實際工作中,JavaScript正則表達(dá)式還是經(jīng)常用到的。所以這部分的知識是非常重要的。
一、基礎(chǔ)語法:
第一種:字面量語法
var expression=/pattern/flags;
第二種:RegExp構(gòu)造函數(shù)語法
var pattern = /\w/gi; //字面量語法
var pattern = new RegExp('\\w', 'gi');//構(gòu)造函數(shù)語法,這兩者是等價的
這里有個注意點就是:如果正則表達(dá)式是動態(tài)的話,只能選擇第二種。
其中的flags有3個標(biāo)志
g:表示全局模式,即模式將被應(yīng)用于所有字符串,而非在發(fā)現(xiàn)第一個匹配項時立即停止;
i:表示不區(qū)分大小寫模式,即在確定匹配項時忽略模式與字符串的大小寫;
m:表示多行模式,即在到達(dá)一行文本末尾時還會繼續(xù)查找下一行中是否存在與模式匹配的項。
當(dāng)然還有其他的flags,用到的極少,不做過多闡述。
至于以上的\w什么意思,稍等,請繼續(xù)往下看。
二、方法
主要有test(),search(),match(),replace()。當(dāng)然還有其它的很多方法,不作闡述,畢竟用到的很少。
1、test()方法的使用
判斷某個字符串中是否含有相應(yīng)的字符串
2、search()方法的使用
搜索相應(yīng)的字符串第一次出現(xiàn)的索引位置,如果未找到,則返回-1
3、match()方法的使用
返回匹配的數(shù)組
4、replace()方法的使用,這個用到的還是非常多的
匹配相應(yīng)的字符串,然后將其替換成其他字符串
三、匹配表達(dá)式跟實戰(zhàn)
1、斷言:
所謂的斷言呢,就是表示一個匹配在某些條件下發(fā)生。總之呢,概念有點繞,直接看下文。待我慢慢續(xù)來。
| 字符 | 描述 |
|---|---|
| ^ | 匹配開頭 |
| $ | 匹配結(jié)尾 |
| \b | 匹配單詞的邊界 |
| \B | 匹配非單詞的邊界 |
舉個例子
我要匹配一個字符串,開頭到結(jié)尾是dog,忽略大小寫
var pattern = /^dog$/i;//忽略大小寫
console.log(pattern.test('dog'));//true
console.log(pattern.test('sdfdog'));//false
console.log(pattern.test('dog56'));//false
console.log(pattern.test('dOG'));//true
var pattern = /\b\w+/g;//全局匹配,這里的+,是量詞,代表1次或者多次
console.log('Hello World'.match(pattern));//輸出['Hello','World'],這里就是match用法,返回匹配的數(shù)組。
在這里,說下,\b是匹配單詞的邊界,那么\B是匹配非單詞的邊界。一個小寫,一個大寫,大寫是反義。那么不必我多說了吧。
再說下單詞邊界,可能很多人都不太清楚單詞邊界
我稍微解釋下啊,比如說,Hello World單詞邊界有四個,分別是H位置,o位置,W位置,d位置
2、字符類:
| 元字符 | 描述 |
|---|---|
| . | 查找單個字符,除了換行和行結(jié)束符 |
| \w | 查找單詞字符,相當(dāng)于[A-Za-z0-9_] |
| \W | 查找非單詞字符,相當(dāng)于[^A-Za-z0-9_] |
| 下面的反義便不再羅列出來了。 | |
| \d | 查找數(shù)字,相當(dāng)于[0-9] |
| \s | 查找空白字符 |
| \0 | 查找NULL字符 |
| \n | 查找換行符 |
| \f | 查找換頁符 |
| \r | 查找回車符 |
| \t | 查找制表符 |
| \v | 查找垂直制表符 |
3、范圍:
| 字符 | 描述 |
|---|---|
| [abc] | 匹配a,b,c中的任意一個字符 |
| [^abc] | 匹配不是a,b,c中的任意一個字符 |
| [0-9] | 匹配0-9任意范圍的數(shù)字,同理[a-z]匹配a-z任意范圍的字符 |
| [a-z] | 匹配a到z之間的任意一個字符 |
| x|y | 匹配x或者y |
4、量詞:
| 字符 | 描述 |
|---|---|
| n+ | 匹配任何包含至少一個字符n的字符串 |
| n* | 匹配任何包含零個或多個n的字符串 |
| n? | 匹配任何包含零個或者一個n的字符串 |
| n{x} | 匹配包含x個n的字符串 |
| n{x,y} | 匹配最少x個,最多y個n的字符串 |
四、拓展
匹配10-36之間的數(shù)字
var pattern = /1[2-9]|[2-3][0-9]|4[0-6]/;//12-46 console.log(pattern.test(11));//false console.log(pattern.test(12));//true console.log(pattern.test(20));//true console.log(pattern.test(36));//true console.log(pattern.test(46));//true console.log(pattern.test(47));//false
將'Hello,World!Hello'中的Hello替換成Welcome
這里主要是強調(diào)一下replace方法在正則中的使用,因為這個在實際中用到的還是非常多的。后面的flags中的g,加上跟不加上有著很大的區(qū)別的。
var pattern = /Hello/g; var oldString = 'Hello,World!Hello'; var newString = oldString.replace(pattern, 'Welcome'); console.log(newString);//Welcome,World!Welcome
總結(jié)
到此這篇關(guān)于JavaScript中正則表達(dá)式的實際應(yīng)用的文章就介紹到這了,更多相關(guān)JavaScript正則表達(dá)式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在layui中l(wèi)ayer彈出層點擊事件無效的解決方法
今天小編就為大家分享一篇在layui中l(wèi)ayer彈出層點擊事件無效的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09
BootStrap實現(xiàn)帶關(guān)閉按鈕功能
這篇文章主要介紹了BootStrap實現(xiàn)帶關(guān)閉按鈕功能,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-02-02
javascript代碼編寫需要注意的7個小細(xì)節(jié)小結(jié)
每種語言都有它特別的地方,對于JavaScript來說,使用var就可以聲明任意類型的變量,這門腳本語言看起來很簡單,然而想要寫出優(yōu)雅的代碼卻是需要不斷積累經(jīng)驗的。本文利列舉了JavaScript初學(xué)者應(yīng)該注意的七個細(xì)節(jié),與大家分享。2011-09-09
js CSS3實現(xiàn)卡牌旋轉(zhuǎn)切換效果
這篇文章主要為大家詳細(xì)介紹了js CSS3實現(xiàn)卡牌旋轉(zhuǎn)切換效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07
javascript onkeydown,onkeyup,onkeypress,onclick,ondblclick
昨天群里面的朋友問了個比較有意思的問題,keydown,keyup,keypress事件的先后順序。2009-02-02
Javascript 模擬mvc實現(xiàn)點餐程序案例詳解
這篇文章主要介紹了Javascript 模擬mvc實現(xiàn)點餐程序案例詳解,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12

