91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript中RegExp對象屬性的示例分析

發布時間:2021-08-19 14:48:23 來源:億速云 閱讀:94 作者:小新 欄目:web開發

這篇文章主要介紹了JavaScript中RegExp對象屬性的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

解釋

每個RegExp對象都包含5個屬性,source、global、ignoreCase、multiline、lastIndex。

source:是一個只讀的字符串,包含正則表達式的文本。

var reg = /JavaScript/;
reg.source; //返回 JavaScript

global:是一個只讀的布爾值,看這個正則表達式是否帶有修飾符g。

修飾符g,是全局匹配的意思,檢索字符串中所有的匹配。

var str = "JavaScript";
str.match(/JavaScript/); //只能匹配一個JavaScript 
var str = "JavaScript JavaScript";
str.match(/JavaScript/g); //能匹配兩個JavaScript 
var reg = /JavaScript/;
reg.global; //返回 false
var reg = /JavaScript/g;
reg.global; //返回 true

ignoreCase:是一個只讀的布爾值,看這個正則表達式是否帶有修飾符i。

修飾符i,說明模式匹配是不區分大小寫的。

var reg = /JavaScript/;
reg.ignoreCase; //返回 false
var reg = /JavaScript/i;
reg.ignoreCase; //返回 true
var reg = /JavaScript/;
reg.test("javascript"); //返回 false
var reg = /JavaScript/i;
reg.test("javascript"); //返回 true

multiline:是一個只讀的布爾值,看這個正則表達式是否帶有修飾符m。

修飾符m,用以在多行模式中執行匹配,需要配合^ 和 $</code> 使用,使用<code>^</code> 和 <code>$ 除了匹配整個字符串的開始和結尾之外,還能匹配每行的開始和結尾。

var str="java\nJavaScript";
str.match(/^JavaScript/); //返回null
var str="java\nJavaScript";
str.match(/^JavaScript/m); //匹配到一個JavaScript
var reg=/JavaScript/;
reg.multiline; //返回false
var reg=/JavaScript/m;
reg.multiline; //返回true

lastIndex:是一個可讀/寫的整數,如果匹配模式中帶有g修飾符,這個屬性存儲在整個字符串中下一次檢索的開始位置,這個屬性會被exec( ) 和 test( ) 方法用到。

exec( )方法是在一個字符串中執行匹配檢索,如果它沒有找到任何匹配,它就返回null,但如果它找到了一個匹配,它就返回一個數組。

當調用exec( )的正則表達式對象具有修飾符g時,它將把當前正則表達式對象的lastIndex屬性設置為緊挨著匹配子串的字符位置,當同一個正則表達式第二次調用exec( ),它會將從lastIndex屬性所指示的字符串處開始檢索,如果exec( )沒有發現任何匹配結果,它會將lastIndex重置為0。

JavaScript中RegExp對象屬性的示例分析

test( )方法,它的參數是一個字符串,用test( )對某個字符串進行檢測,如果包含正則表達式的一個匹配結果,則返回true,否則返回false。

var str="java";
var reg=/JavaScript/;
reg.test(str); //返回false
var str="JavaScript";
var reg=/JavaScript/;
reg.test(str); //返回true

當調用test( )的正則表達式對象具有修飾符g時,它的行為和exec( )相同,因為它從lastIndex指定的位置處開始檢索某個字符串,如果它找到了一個匹配結果,那么它就立即設置lastIndex為緊挨著匹配子串的字符位置

看看下面這段有趣的代碼

var str="JavaScript";
var reg=/JavaScript/g;
console.log(reg.test(str)); //打印 true
console.log(reg.test(str)); //打印 false

為什么同樣的字符串,同樣的正則表達式,卻打印的不一樣,如果你已經理解了 lastIndex屬性,那你一定明白為什么。

我們來看看到底發什么了什么

var str="JavaScript";
var reg=/JavaScript/g;
console.log(reg.test(str)); //打印 true
console.log(reg.lastIndex);
//打印10,因為匹配到了JavaScript,所以設置lastIndex為匹配結果緊挨著的字符位置
console.log(reg.test(str));
//打印 false,因為從lastIndex位置檢索字符串,已經沒有匹配結果了
console.log(reg.lastIndex);
//打印0,因為沒有匹配到結果,所以將lastIndex重置為0

這里注意一點,如果第一次調用test( )匹配結束后,我們手動將lastIndex重置為0,那么第二次調用test( ),同樣可以打印true

var str="java JavaScript java";
var reg=/JavaScript/g;
console.log(reg.test(str)); //打印 true
reg.lastIndex=0;
console.log(reg.test(str)); //打印 true

在強調一次,上面說的關于lastIndex的問題,都是因為正則表達式對象中帶有修飾符g,如果不帶有修飾符g,就不用擔心這些問題了。

感謝你能夠認真閱讀完這篇文章,希望小編分享的“JavaScript中RegExp對象屬性的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

绥德县| 菏泽市| 深圳市| 五原县| 家居| 阿克苏市| 石嘴山市| 曲靖市| 田东县| 东城区| 沙坪坝区| 乐平市| 松滋市| 阳泉市| 偃师市| 德格县| 新乐市| 浮梁县| 进贤县| 日照市| 陆河县| 新乡县| 富锦市| 诏安县| 宁安市| 汪清县| 西青区| 南涧| 温宿县| 马山县| 民乐县| 涿鹿县| 龙里县| 盐津县| 佳木斯市| 广宗县| 遵义市| 荥阳市| 乌鲁木齐县| 湖南省| 孟连|