淺談js中的正則表達式

来源:http://www.cnblogs.com/WeiRuifeng/archive/2017/06/23/7070711.html
-Advertisement-
Play Games

很多時候多會被正則表達式搞的暈頭轉向,最近抽出時間對正則表達式進行了系統的學習,整理如下: 正則表達式的創建 兩種方法,一種是直接寫,由包含在斜杠之間的模式組成;另一種是調用RegExp對象的構造函數。 兩種方法的創建代碼如下: 可以看出,調用RegExp構造函數創建正則表達式時,第一個參數可以是字 ...


很多時候多會被正則表達式搞的暈頭轉向,最近抽出時間對正則表達式進行了系統的學習,整理如下:

正則表達式的創建

兩種方法,一種是直接寫,由包含在斜杠之間的模式組成;另一種是調用RegExp對象的構造函數。

兩種方法的創建代碼如下:

// 直接創建
const regex1 = /ab+c/;
const regex2 = /^[a-zA-Z]+[0-9]*\W?_$/gi;

// 調用構造函數
const regex3 = new RegExp('ab+c');
const regex4 = new RegExp(/^[a-zA-Z]+[0-9]*\W?_$/, "gi");
const regex5 = new RegExp('^[a-zA-Z]+[0-9]*\W?_$', 'gi');

可以看出,調用RegExp構造函數創建正則表達式時,第一個參數可以是字元串,也可以是直接創建的正則表達式。

需要註意的是:RegExp實例繼承的toLocaleString()和toString)()方法都會返回正則表達式的字面量,與創建正則表達式的方式無關

例如:

const ncname = '[a-zA-Z_][\\w\\-\\.]*';
const qnameCapture = '((?:' + ncname + '\\:)?' + ncname + ')';
const startTagOpen = new RegExp('^<' + qnameCapture);
startTagOpen.toString();        // '/^<((?:[a-zA-Z_][\w\-\.]*\:)?[a-zA-Z_][\w\-\.]*)/'

 

正則表達式中的特殊字元

\ (反斜杠)

1.在非特殊字元前加反斜杠表示下一個字元是特殊的;

2.將其後的特殊字元轉譯為字面量;

註意:在使用RegExp構造函數時要將\轉譯,因為\在字元串里也是轉譯字元

1.匹配輸入的開始;

2.在[]中的第一位時表示反向字元集;

例子:

 

/^A/.exec('an A')        // null
/^A/.exec('An E')        // ["A", index: 0, input: "An E"]

 

匹配輸入的結束

/t$/.exec('eater')        // null
/t$/.exec('eat')          // ["t", index: 2, input: "eat"]

*,  +,  .(小數點) 

*:匹配前一個表達式0次或多次。等價於 {0,};

+:匹配前面一個表達式1次或者多次。等價於 {1,};

.:匹配除換行符之外的任何單個字元;

? (問號)

1.匹配前面一個表達式0次或者1次。等價於 {0,1};
2.如果緊跟在任何量詞 * + ? {} 的後面,將會使量詞變為非貪婪的(匹配儘量少的字元),和預設使用的貪婪模式正好相反;
3.運用於先行斷言

例子:

/\d+/.exec('123abc')           // ["123", index: 0, input: "123abc"]
/\d+?/.exec('123abc')            // ["1", index: 0, input: "123abc"]

(x)

匹配 'x' 並且記住匹配項,括弧表示捕獲括弧;

例子:

/(foo) (bar) \1 \2/.test('bar foo bar foo');   // false
/(bar) (foo) \1 \2/.test('bar foo bar foo');   // true
/(bar) (foo) \1 \2/.test('bar foo');           // false
/(bar) (foo) \1 \2/.test('bar foo foo bar');   // false
/(bar) (foo) \2 \1/.test('bar foo foo bar');   // true

'bar foo bar foo'.replace( /(bar) (foo)/, '$2 $1' );    // "foo bar bar foo"

模式 /(foo) (bar) \1 \2/ 中的 '(foo)' 和 '(bar)' 匹配並記住字元串 "foo bar foo bar" 中前兩個單詞。模式中的 \1 和 \2 匹配字元串的後兩個單詞。

註意:\1、\2、\n 是用在正則表達式的匹配環節,在正則表達式的替換環節,則要使用像 $1、$2、$n 這樣的語法。例如,'bar foo'.replace( /(...) (...)/, '$2 $1' )。

(?:x) 

匹配 'x' 但是不記住匹配項,這種叫作非捕獲括弧;

例子:

'foo'.match(/foo{1,2}/)                // ["foo", index: 0, input: "foo"]
'foo'.match(/(?:foo){1,2}/)            // ["foo", index: 0, input: "foo"]
'foofoo'.match(/(?:foo){1,2}/)         // ["foofoo", index: 0, input: "foofoo"]
'foofoo'.match(/foo{1,2}/)             // ["foo", index: 0, input: "foofoo"]

使用場景:示例表達式 /(?:foo){1,2}/。如果表達式是 /foo{1,2}/,{1,2}將只對 ‘foo’ 的最後一個字元 ’o‘ 生效。如果使用非捕獲括弧,則{1,2}會匹配整個 ‘foo’ 單詞。

x(?=y), x(?!y), x|y 

x(?=y):匹配'x'僅僅當'x'後面跟著'y';

x(?!y):匹配'x'僅僅當'x'後面不跟著'y';

x|y: 匹配x或y

這兩種匹配的結果都不包含y

例子:

'JackSprat'.match(/Jack(?=Sprat)/)            // ["Jack", index: 0, input: "JackSprat"]
'JackWprat'.match(/Jack(?=Sprat)/)            // null
'JackWprat'.match(/Jack(?=Sprat|Wprat)/)    // ["Jack", index: 0, input: "JackWprat"]
/\d+(?!\.)/.exec("3.141")        // ["141", index: 2, input: "3.141"]

{n}, {n,m}:

{n}:匹配了前面一個字元剛好發生了n次;

{n,m}:匹配前面的字元至少n次,最多m次。如果 n 或者 m 的值是0, 這個值被忽略;

例子:

    /a{2}/.exec('candy')         // null
    /a{2}/.exec('caandy')        // ["aa", index: 1, input: "caandy"]
    /a{2}/.exec('caaandy')       // ["aa", index: 1, input: "caaandy"]

    /a{1,3}/.exec('candy')       // ["a", index: 1, input: "candy"]
    /a{1,3}/.exec('caandy')      // ["aa", index: 1, input: "caandy"]
    /a{1,3}/.exec('caaandy')     // ["aaa", index: 1, input: "caaandy"]
    /a{1,3}/.exec('caaaandy')    // ["aaa", index: 1, input: "caaaandy"]
    

[xyz], [^xyz] 

[xyz]:一個字元集合。匹配方括弧的中任意字元;

[^xyz]:一個反向字元集。匹配任何沒有包含在方括弧中的字元;

這兩種匹配都可以使用破折號(-)來指定一個字元範圍,特殊符號在字元集中沒有了特殊意義。

例:

function escapeRegExp(string){
    return string.replace(/([.*+?^=!:${}()|[\]\/\\])/g, "\\$&"); 
    //$&表示整個被匹配的字元串
}

例子中的.*+?^=!:${}()都表示字面量,並沒有特殊意義。

其他

\b:匹配一個詞的邊界。一個匹配的詞的邊界並不包含在匹配的內容中。換句話說,一個匹配的詞的邊界的內容的長度是0;

\B: 匹配一個非單詞邊界;

例子:

    /\bm/.exec('moon')                    // ["m", index: 0, input: "moon"]
    /\bm/.exec('san moon')                // ["m", index: 4, input: "san moon"]
    /oo\b/.exec('moon')                   // null
    /\B../.exec('noonday')                    // ["oo", index: 1, input: "noonday"]
    /y\B../.exec('possibly yesterday')        // /y\B../.exec('possibly yesterday')

\d:匹配一個數字,等價於[0-9];

\D:匹配一個非數字字元,等價於[^0-9];

\f:匹配一個換頁符 (U+000C);

\n:匹配一個換行符 (U+000A);

\r:匹配一個回車符 (U+000D);

\s:匹配一個空白字元,包括空格、製表符、換頁符和換行符,等價於[ \f\n\r\t\v\u00a0\u1680\u180e\u2000-\u200a\u2028\u2029\u202f\u205f\u3000\ufeff];

\S:匹配一個非空白字元,等價於[^ \f\n\r\t\v\u00a0\u1680\u180e\u2000-\u200a\u2028\u2029\u202f\u205f\u3000\ufeff];

\w:匹配一個單字字元(字母、數字或者下劃線),等價於[A-Za-z0-9_];

\W:匹配一個非單字字元,等價於[^A-Za-z0-9_];

正則表達式標誌

g:全局搜索;

i:不區分大小寫;

m:多行搜索;

正則表達式使用

RegExp有exec()和test()方法;

exec匹配的結果為:匹配結果、捕獲結果,index和input。

test匹配的結果為true或false,效率比exec要高。

String有match(),replace(),search(),split()方法;

match匹配的結果同RegExp的exec,replace根據正則表達式替換,search查找所以位置,split根據正則表達式分割字元串。

其中,當replace有function時,參數說明如下:

* 匹配項
* 記憶項(括弧裡面的項)
* ...
* 匹配的index
* input輸入項

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 如果滾動頁面也是DOM沒有解決的一個問題。為瞭解決這個問題,瀏覽器實現了一下方法,以方便開發人員如何更好的控制頁面的滾動。在各種專有方法中,HTML5選擇了scrollIntoView()作為標準方法。scrollIntoView()可以在所有的HTML元素上調用,通過滾動瀏覽器視窗或某個容器元素, ...
  • 這個對象,不是那個對象,第三哦! 對象之間會存在繼承,所以,來說一下他們之間存在的三種三種繼承方式: 1、冒用繼承 這就是第一種繼承方式。 【註意】冒用繼承缺點:不能使用原型上的方法和屬性 優點:可以傳遞參數; 2、原型繼承 這種繼承方式就是將新建的父類對象賦給子類構造函數的原型。 【註意】原型鏈繼 ...
  • 之前在寫頁面的時候用的都是單行文字溢出隱藏,今天遇到了多行文字溢出隱藏,溢出部分用省略號。我通過查閱一些資料整理了一下,拿出來與大家分享一下。 單行文本的溢出隱藏 對於單行文本溢出 隱藏,text-overflow: ellipsis 就能完美的解決,不過在使用他時,一定要結合 overflow: ...
  • 如何垂直居中一個浮動元素 // 方法一:已知元素的高寬 #div1{ width:200px; height:200px; position: absolute; /*父元素需要相對定位*/ top: 50%; left: 50%; margin-top:-100px ; /*二分之一的height ...
  • html +css 靜態頁面 js 動態 交互 原理: js就是修改樣式, 比如彈出一個對話框. 彈出的過程就是這個框由disable 變成display:enable. 又或者當滑鼠指向的時候換一個顏色,就是一個修改樣式的工具. 編寫JS的流程 佈局:HTML+CSS 事件:確定用戶做哪些操作(產... ...
  • windows系統中,本地向自身發送數據包沒有經過真實的網路介面,而是通過環路(loopback interface)介面發送,所以使用基於只能從真實網路介面中抓數據的winpcap是無法抓取本地數據包,需要使用npcap,npcap是基於winpcap 4.1.3開發的,api相容WinPcap, ...
  • jQuery Validate jQuery Validate 插件為表單提供了強大的驗證功能,讓客戶端表單驗證變得更簡單,同時提供了大量的定製選項,滿足應用程式各種需求。 1.首先,如果我們沒有jquery.validata.js那就需要下載了。 點擊神賜下載鏈接 2.創建運行環境,也就是引入我們 ...
  • 前提:調用微信jssdk分享功能,通過微信開發者工具調試,調用正常,無任何報錯信息。 問題:調用成功,且開發者工具正常顯示,但是通過真機調試,分享出去後,自定義內容失效,為微信自動獲取的預設內容!截止發稿日:IOS端一切正常(可能IOS端規則還沒有變),Android端分享操作正常,自定義內容失效。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...