JavaScript 正則表達(dá)式與字符串查找方法
首先提出一個(gè)問題:
如何取得一個(gè)給定的字符串substr在另一個(gè)字符串str中出現(xiàn)的次數(shù)?
字符串匹配,第一想到的就是正則表達(dá)式,但我們最常使用的字面量來創(chuàng)建的正則表達(dá)式方式卻無(wú)法傳入變量,
這時(shí)應(yīng)該使用另一種創(chuàng)建正則表達(dá)式的方式:構(gòu)造函數(shù),如下
var reg = new RegExp(substr, "g");
其中第一個(gè)參數(shù)表示要匹配的字符串模式,因此可以傳入變量,不需要加/ /,第二個(gè)參數(shù)是可選的標(biāo)志字符串。
可以傳入變量了,再介紹個(gè)字符串基本包裝類型的方法:match()
語(yǔ)法為str.match(regExp),參數(shù)為一個(gè)正則表達(dá)式,若傳的不是正則則會(huì)隱式轉(zhuǎn)換,返回值為一個(gè)包含匹配結(jié)果的數(shù)組,如果沒有匹配項(xiàng),則返回null。
另外,字符串的match方法與正則的exec()類似,返回匹配的詳細(xì)信息;字符串的search方法與正則的test()類似,只是用來查看是否匹配。
回到最初的問題,完整的程序如下:
var str1 = "abctestctesqk1test23"; var str2 = "test"; function countSubstr(str, substr) { var reg = new RegExp(substr, "g"); return str.match(reg) ? str.match(reg).length : 0;//若match返回不為null,則結(jié)果為true,輸出match返回的數(shù)組(["test","test"])的長(zhǎng)度 } console.log(countSubstr(str1, str2));//輸出2
另外,對(duì)于變量的問題,不使用構(gòu)造函數(shù)也可以解決,即使用eval():
var reg = "/" + substr + "/g"; reg = eval(reg);//不推薦!
但都知道不推薦使用eval()方法,所以還是推薦使用構(gòu)造函數(shù)方法。
但還是有個(gè)問題,如果子字符串中含有正則表達(dá)式中所謂的元字符(即+*?^等),則無(wú)法正常匹配。
因?yàn)榇藭r(shí)正則表達(dá)式是在字符串里的,\是字符串中的轉(zhuǎn)義符,也是正則表達(dá)式中的轉(zhuǎn)義符。那么只加一個(gè)\的話,只能說明在字符串中轉(zhuǎn)義,而js需要進(jìn)一步把普通字符串中的\變成正則表達(dá)式中的\,像是更深一則轉(zhuǎn)化的意思,稱為雙重轉(zhuǎn)義,這樣\\以后的意思是正則表達(dá)式中的轉(zhuǎn)義符(\)。
所以對(duì)于那些元字符如果不進(jìn)行雙重轉(zhuǎn)義,則無(wú)法真正查找要找的那個(gè)字符。這個(gè)問題尚未解決,不過一般字符串查找也很少有這些特殊字符吧,可以先一用。
以上這篇JavaScript 正則表達(dá)式與字符串查找方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
正則表達(dá)式(regex)簡(jiǎn)介和基本用法小結(jié)
正則表達(dá)式 (regex) 是用于模式匹配和文本操作的強(qiáng)大工具, 它們廣泛應(yīng)用于編程、文本處理、數(shù)據(jù)驗(yàn)證等領(lǐng)域,這篇文章主要介紹了正則表達(dá)式 (regex) 簡(jiǎn)介和基本用法,需要的朋友可以參考下2024-04-04解決正則表示式匹配($regex)引起的一次mongo數(shù)據(jù)庫(kù)cpu占用率高的問題
這篇文章主要介紹了由正則表示式匹配($regex)引起的一次mongo數(shù)據(jù)庫(kù)cpu占用率高的問題,本文通過實(shí)例給大家分析的非常詳細(xì),需要的朋友可以參考下2019-11-11JavaScript正則表達(dá)式實(shí)現(xiàn)注冊(cè)信息校驗(yàn)功能
這篇文章主要介紹了JavaScript正則表達(dá)式實(shí)現(xiàn)注冊(cè)信息校驗(yàn)功能,在JS中默認(rèn)是模糊匹配,只要字符串包含了正則表達(dá)式的內(nèi)容就返回true,本文通過案例分析給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-05-05正則表達(dá)式在IOS中的應(yīng)用及IOS中三種正則表達(dá)式的使用與比較
本篇文章給大家介紹正則表達(dá)式在IOS中應(yīng)用以及IOS中三種正則表達(dá)式式的使用與比較,感興趣的朋友跟著小編一起來學(xué)習(xí)學(xué)習(xí)吧2015-09-09javascript RegExp multiline多行匹配影響的^$
javascript RegExp multiline多行匹配影響的^$,代碼中有詳細(xì)的注釋,方法大家學(xué)習(xí)。2010-03-03