DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> 使用JS中的exec()方法構造正則表達式驗證
使用JS中的exec()方法構造正則表達式驗證
編輯:關於JavaScript     

正則表達式,又稱正規表示法、常規表示法。(英語:Regular Expression,在代碼中常簡寫為regex、regexp或RE),計算機科學的一個概念。正則表達式使用單個字符串來描述、匹配一系列符合某個句法規則。在很多文本編輯器裡,正則表達式通常被用來檢索、替換那些符合某個模式的文本。

一、Javascript中的正則表達式

在Javascript中,可以使用RegExp對象構造正則表達。我們需要新建一個實例化的RegExp()對象,可以傳入兩個參數:第一個參數是匹配的模式,第二個參數是一個可選項,可以傳入三種參數。i表示不區分大小寫,g表示全局匹配,即匹配所有的符合條件的字符串,m表示執行多次匹配。實例如下:

復制代碼 代碼如下:
var reg = new RegExp("Hello", "i"); //表示匹配字符串中的Hello字符串,並且不區分大小寫。

二、使用exec進行模式匹配

RegExp中有一個方法可以進行模式匹配並返回結果:exec()。該方法非常重要,基本是使用js進行模式匹配必用的函數。然而該函數的返回值有很多人並不清楚,因此在實際使用的時候經常會出錯。在這裡系統的介紹一些exec()的使用方法。

exec()的基本格式為:RegExpObject.exec(string),其中RegExpObject為設置好的正則匹配對象,string為待匹配的字符串。如果成功匹配,則返回一個數組;如果沒有成功匹配的字符串部分,則返回null。

這裡的重點就在於這個數組。數組返回的到底是什麼呢?可以看一下下面這個實驗.

復制代碼 代碼如下:
var re = new RegExp("[?#&]" + user + "=([^&#]*)", "i")

這段代碼進行了一個url的匹配,可以用來獲得user=後面的參數部分,那麼如果使用一個url並且用這個模式進行exec操作,結果會返回什麼呢?比如我們有如下

www.qq.com?user=Tom&psw=123456

exec返回的數組結果為:[?user=Tom, Tom]。可以看到返回數組的第一個元素就是整個的匹配模式所匹配到的字符串,而第二個匹配到的字符恰好是參數值。

這是exec匹配返回的規則:第一個元素為整個的匹配字符串,從第二個參數開始返回模式中每一個()所定義的分組所匹配的字符串。

這裡面([^&#]*)返回的就是不以&或#開頭的字符串,即後面對應的參數。

如果我們將定義的模式修改為[?#&]" + (user) + "=([^&#]*),那麼exec()後返回的數組就是[?user=Tom, user, Tom]。

以上所述是小編給大家介紹的使用JS中的exec()方法構造正則表達式驗證,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對網站的支持!

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved