溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

什么是正則表達(dá)式

發(fā)布時(shí)間:2021-09-16 14:25:44 來(lái)源:億速云 閱讀:179 作者:小新 欄目:互聯(lián)網(wǎng)科技

這篇文章主要為大家展示了“ 什么是正則表達(dá)式”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“ 什么是正則表達(dá)式”這篇文章吧。

 什么是正則表達(dá)式:

簡(jiǎn)單的說(shuō),正則表達(dá)式是一種可以用于模式匹配和替換的強(qiáng)大工具。在幾乎所有的基于UNIX/LINUX系統(tǒng)的軟件工具中找到正則表達(dá)式的痕跡,例如:Perl或PHP腳本語(yǔ)言。此外,JavaScript這種客戶(hù)端的腳本語(yǔ)言也提供了對(duì)正則表達(dá)式的支持,現(xiàn)在正則表達(dá)式已經(jīng)成為了一個(gè)通用的概念和工具,被各類(lèi)技術(shù)人員所廣泛使用。

正則表達(dá)式基本語(yǔ)法

一、創(chuàng)建JavaScript正則(RegExp)對(duì)象

var reg = RegExp('s');
var reg = /s/; // 簡(jiǎn)寫(xiě)方式 推薦使用 不能為空 不然會(huì)以為是注釋

二、預(yù)定義符

開(kāi)始前先看一些符號(hào)表達(dá)的意思才好幫助你對(duì)下面的例子可以迅速的理解

\s : 空格
\S : 非空格
\d : 數(shù)字
\D : 非數(shù)字
\w : 字符
\W : 非字符
\i : 不區(qū)分大小寫(xiě)
\g : 全局匹配(一般正則找到第一個(gè)符合條件的就會(huì)停止,在后面加上這個(gè)符合就會(huì)告訴正則繼續(xù)往下不要停)
| : 或
. : 任意字符
\b : 獨(dú)立的部分 ( 起始,結(jié)束,空格 )
\B : 非獨(dú)立的部分
\n : 重復(fù)的某個(gè)子項(xiàng),例如

 var reg = /(a)(b)(c)\1/; //=> abca 重復(fù)了a子項(xiàng)

如需使用真正的符號(hào)例如“.”,只需添加\即可,如\.

三、常用的幾個(gè)方法

1. test() => 在字符串中查找符合正則指定的內(nèi)容,若找到返回true,否則返回false

 // 用法:正則.test(字符串)
var data = '123456789987654321';
var reg = /\d/; // \d這里代表數(shù)字
if( reg.test(str) ){ 
 console.log('內(nèi)容為數(shù)字');
 console.log(reg.test(str)) // 返回 true
}

2. match() => 在字符串中查詢(xún)符合正則指定的內(nèi)容,成功則返回內(nèi)容(數(shù)組格式),否則返回null

// 用法:字符串.match(正則)
var data = '123456mple789Mple875654';
var reg = /mple/gi;
console.log(data.match(reg)); // mple,Mple

3. search() => 在字符串中查詢(xún)符合正則指定的內(nèi)容,成功找到則返回當(dāng)前內(nèi)容的位置從0開(kāi)始(如不止一個(gè)內(nèi)容符合正則條件,則返回第一個(gè)找到的位置),如果沒(méi)找到則返回-1

// 用法:字符串.search(正則)
var data = '1234mple56789Mple987mple654321';
var reg = /mple/gi;
console.log(data.search(reg)); // 4

4. replace() => 在字符串中查詢(xún)符合正則指定的內(nèi)容,查找到則替換對(duì)應(yīng)內(nèi)容并返回替換后的內(nèi)容

// 用法:字符串.replace(正則,新的字符串/回調(diào)函數(shù))
var data = '啦啦啦~一大堆啦啦啦';
var reg = /啦/g;
var rep = data.replace(reg,function(data){
 var ne = '';
 for(var i=0; i<data.length; i++){
 ne += '*';
 }
 return ne;
});
console.log(rep);

5. exec() => 查找并返回當(dāng)前的匹配結(jié)果,以數(shù)組的形式返回

//用法:正則.exec(字符串)
var data = "1234mple5678mple99876mple543Mple21";
var reg = /mple/ig;
var s = reg.exec(data)
console.log(s.index); //4

6. split() = 正則分割字符串

7. sort():數(shù)組中的排序方法,按照ACALL碼進(jìn)行排序

8. join():數(shù)組中的方法,把數(shù)組轉(zhuǎn)換為字符串

var data = '4445554654123156489151321456';
var arr = data.split('');
data = arr.sort().join('');
console.log(data);

四、常用量詞

{n,m} : 至少出現(xiàn)n次,最多m次

{n,} : 至少n次

* : 任意次 相當(dāng)于{0,}

? :零次或一次 相當(dāng)于{0,1}

+ : 查找的結(jié)果至少出現(xiàn)一次或任意次 {1,}

{n} : 正好n次

最后來(lái)個(gè)例子理解理解,判斷QQ號(hào)

HTML

<input class="qq" type="text" placeholder="請(qǐng)輸入QQ號(hào)">
<button type="button" class="sub">檢測(cè)</button>

正則

//先來(lái)看看我們?nèi)粘5卿浀腝Q號(hào)有哪些性質(zhì)
1 首位肯定不是為0 
2 必須是5-10位的數(shù)字
var oInput = document.querySelector('.qq');
var oSub = document.querySelector('.sub');
var reg = /^[1-9]\d{4,9}$/;
//為了防止最后幾位數(shù)出現(xiàn)字母abc之類(lèi)的情況,所以需要添加$進(jìn)行尾數(shù)限制
//所以最后的邏輯是這樣的,首位是0-9,接著是4-9位的數(shù)字類(lèi)型。
oSub.onclick = function(){
 if( reg.test(oInput.value) ){
 alert('檢測(cè)成功');
 }else{
 alert('賬戶(hù)不存在');
 }
};

以上是“ 什么是正則表達(dá)式”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI