怎么使用javascript中的正則表達(dá)式

怎么使用javascript中的正則表達(dá)式?相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

我們提供的服務(wù)有:網(wǎng)站建設(shè)、成都做網(wǎng)站、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、射洪ssl等。為上千多家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的射洪網(wǎng)站制作公司

本節(jié)講正則表達(dá)式在js中的使用,注意正則對象是一個引用類型。

初始化:字面量和對象使用

與對象的定義一樣,我們可以使用字面量定義正則表達(dá)式,也可以使用正則對象來定義正則表達(dá)式,他們的區(qū)別是使用的轉(zhuǎn)義有一定差別。

在使用字面量的時候,使用/ /把正則表達(dá)式包起來,后面可以寫上匹配模式或者不寫,不寫默認(rèn)不是全局匹配,我們在使用的時候,一般都是使用字面量來初始化,因為這樣比較簡單,轉(zhuǎn)義也不像字符串那么復(fù)雜。

// 正則表達(dá)式 /at/g 表示匹配所有at  /g表示全局搜索
var pattern1 = /at/g; // 注意不用字符串
var pattern2 = RegExp('/at', 'g');

下面這些需要轉(zhuǎn)義:
怎么使用javascript中的正則表達(dá)式

正則對象的屬性

由于正則對象的屬性都可以在字面變量中看得到,所以這些方法用處并不大,知道就好:
怎么使用javascript中的正則表達(dá)式

exec() 方法(捕獲方法)

exec方法執(zhí)行的結(jié)果不是所有匹配的項,而是第一個匹配到的項,他的返回值如下面的代碼顯示(關(guān)于捕獲組的概念,我們以后用到了再講,這里我們知道每次只會匹配一個,在數(shù)組的第0個位置返回)

// exec的返回值
var text = 'mom and dad and baby';
var pattern = /mom( and dad( and baby)?)?/gi;

var matches = pattern.exec(text);
alert(matches.index); // 0 // 擁有index屬性標(biāo)識匹配項再字符串中的位置
alert(matches.input); // mom and dad and baby // 標(biāo)識原字符串
alert(matches[0]); //mom and dad  // 標(biāo)識匹配的字符串
alert(matches[1]); //and dad  //捕獲組匹配的字符串
alert(matches[2]); //and baby

exec方法要注意全局標(biāo)志 /g 對于執(zhí)行結(jié)果的影響,不寫/g的時候,不是全局匹配,每一次執(zhí)行都是從頭開始,寫了/g,匹配是全局的,下一次匹配是從上一次的基礎(chǔ)之上繼續(xù)往后匹配,看下面的例子就可以說明這個情況

// 不寫/g  每一次都是從頭開始匹配
var text = 'cat, bat, sat, fat';
var pattern1 = /.at/;
var matches = pattern1.exec(text);
alert(matches.index); //0
alert(matches[0]); //cat
alert(pattern1.lastIndex); //0   //lastIndex方法是問題的關(guān)鍵,注意它是pattern1對象的屬性,其實就記錄了這個正則匹配到哪個位置了,這里都是0說明是一直從零開始匹配

matches = pattern1.exec(text);
alert(matches.index); //0
alert(matches[0]); //cat
alert(pattern1.lastIndex); //0

加上/g我們再看看結(jié)果有什么變化

var text = 'cat, bat, sat, fat';
var pattern1 = /.at/g;
var matches = pattern1.exec(text);
alert(matches.index); //0
alert(matches[0]); //cat
alert(pattern1.lastIndex); //3 //lastIndex標(biāo)識經(jīng)過了這次匹配,下次匹配應(yīng)該從什么位置開始進行

matches = pattern1.exec(text);
alert(matches.index); //5  // 標(biāo)識匹配到的位置
alert(matches[0]); //bat
alert(pattern1.lastIndex); //8

test方法

test方法用于匹配之后返回true false,如果只想知道有無匹配,不想知道具體結(jié)果,就用這個。常用于if語句中,判斷用戶輸入是否有效等。

var text = '000-00-0000';
var pattern = /\d{3}-\d{2}-\d{4}/;

if (pattern.test(text)) {
alert('matched');  //matched
}

全局屬性

通過RegExp的屬性,我們可以獲知一些全局的正則信息,比如剛剛匹配輸入了什么字符串,上次匹配了哪些信息,這個有點像全局的靜態(tài)變量,我們看看全局屬性支持哪些信息的獲取
怎么使用javascript中的正則表達(dá)式
注意使用長屬性名和短屬性名都可以獲取全局屬性。我們下面看看長短屬性的使用
怎么使用javascript中的正則表達(dá)式
怎么使用javascript中的正則表達(dá)式
怎么使用javascript中的正則表達(dá)式

不支持的功能

怎么使用javascript中的正則表達(dá)式

看完上述內(nèi)容,你們掌握怎么使用javascript中的正則表達(dá)式的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

當(dāng)前標(biāo)題:怎么使用javascript中的正則表達(dá)式
網(wǎng)址分享:http://muchs.cn/article28/pihhjp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)建站、自適應(yīng)網(wǎng)站、全網(wǎng)營銷推廣網(wǎng)站設(shè)計公司、建站公司、網(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)

成都網(wǎng)站建設(shè)公司