JS: RegExp(正則表達式)

来源:https://www.cnblogs.com/guolao/archive/2018/11/22/10004367.html
-Advertisement-
Play Games

RegExp語法(包含ES2018標準) 註意:本次所有代碼都僅在Chrome 70中進行測試 1. 正則表達式是什麼? 正則表達式是用於匹配字元串中字元組合的模式。(mdn) 簡單來說,正則表達式是用來提取、捕獲文本(匹配字元)的。 2. 創建: 字面量: 構造函數: 3. 實例屬性: 每個正則表 ...


RegExp (包含ES2018新特性)

註意:本次所有代碼都僅在Chrome 70中進行測試

  1. 正則表達式是什麼?

    正則表達式是用於匹配字元串中字元組合的模式。(mdn)

    簡單來說,正則表達式是用來提取、捕獲文本的。

  2. 創建:

    • 字面量:let regex = / pattern / flags

      let regex1 = /foo/i;
    • 構造函數:let regex = new RegExp(pattern, falgs);

      let regex2 = new RegExp('bar', ig); // ES5
      let regex3 = new RegExp(/bat/im); // ES5
      let regex4 = new RegExp(/cat/ig, 'g'); // ES6
      /* regex4 創建方法在ES5中會拋出TypeError,因為第一個參數已經是一個正則表達式,而ES5不允許此時再使用第二個參數添加修飾符。ES6則允許這種寫法,但第二個參數會作為修飾符覆蓋第一個參數中的修飾符。*/
      console.log(regex4); // /cat/g
  3. 實例屬性:

    每個正則表達式實例都擁有下麵的屬性,以便獲取實例模式的信息。

    • global:布爾值,表示是否設置了 g(全局匹配)標誌。

    • ignoreCase:布爾值,表示是否設置了 i(忽略大小寫)標誌。

    • multiline:布爾值,表示是否設置了 m(多行)標誌。

    • unicode:布爾值,表示是否設置了 u(識別 unicode 字元中大於\uFFFF的 unicode 字元)標誌。

    • sticky:布爾值,表示是否設置了 y(粘連)標誌。

    • lastIndex:上次成功匹配後的索引位置,會成為下次匹配的開始索引位置,只在全局匹配或粘滯匹配模式下可用。

    • source:正則表達式中pattern (模式)的字元串表示,與調用toString()或者valueOf()方法得到的結果並不一樣。

    • flags:返回正則表達式中flags(修飾符)的字元串表示。

    • dotAll:返回一個布爾值,表示是否設置了 s(dotAll)標誌。

      let str2 = 'batfoocat';
      let pattern2 = /at/g;
      
      pattern2.global;  // true
      pattern2.sticky;  // false
      pattern2.source; // at
      pattern2.flags; // g
      pattern2.toString(); // /at/g
      pattern2.valueOf(); // /at/g
      pattern2.lastIndex; // 0
      
      let matches = pattern2.exec(str2); // 第一次
      matches[0]; // at
      matches.index; // 1
      pattern2.lastIndex; // 3
      
      matches = pattern2.exec(str2); // 第二次
      matches[0]; // at
      matches.index; // 7
      pattern2.lastIndex; // 9
      
      /*第三次會出現報錯,是因為已經沒有匹配項了,exec()方法返回了null,再執行第四次就會返回第一次匹配的結果,即重新開始匹配*/
      matches = pattern2.exec(str2); // 第三次
      matches[0]; // error
      matches.index); // error
      pattern2.lastIndex; // 0

      補充:已經廢棄的屬性(https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Deprecated_and_obsolete_features)

      這些廢棄的特性仍然可以使用,但你要保持謹慎,因為它們很可能會在未來的某個時候被刪除.(mdn)

  4. 方法:

    • exec:在指定字元串中進行匹配字元,每次只會返回一個匹配項的信息。

      匹配成功,則返回一個數組,並更新正則表達式實例的屬性,否則返回 null。

      返回的數組是 Arrary 實例,但包含了兩個屬性:index(匹配項在字元串中的位置)和 input(正則表達式進行匹配的字元串),數組第一項(下標0)存放匹配到的文本。

      註意:如果使用了全局匹配(g),再次使用exec()方法會返回第二個匹配項的信息,否則無論使用多少次exec()方法都只會返回第一個匹配項信息。

      補充:ES2018在返回數組中新增了一個屬性groups(命名捕獲組的信息)

      let str1 = 'batfoocat';
      let pattern1 = /at/g;
      pattern1.exec(str1); // 第一次
      // ["at", index: 1, input: "batfoocat", groups: undefined]
      pattern1.exec(str1); // 第二次
      // ["at", index: 7, input: "batfoocat", groups: undefined]
      pattern1.exec(str1); // 第三次
      // null
      // 第四次會重新開始匹配,即返回第一次匹配的結果
    • test():測試當前正則表達式是否能匹配目標字元串,返回布爾值。

      let str3 = 'batfoocat';
      let str4 = 'abcde';
      let pattern3 = /at/g;
      pattern3.test(str3); // true
      pattern3.test(str4); // false
    • String.prototype.search():檢索與正則表達式相匹配的子字元串,匹配成功返回第一個匹配項在字元串中的下標,否則返回-1。

      let str5 = 'abcdea';
      str5.search(/a/g); // 0
      str5.search(/f/g); // -1
    • String.prototype.match():檢索與正則表達式相匹配的子字元串,匹配成功返回一個存放所有匹配項的數組,否則返回null,如果正則表達式中沒有標誌 g(全局標誌),那麼match()方法就只能執行一次匹配。

      註意:在全局檢索模式下,match() 即不提供與子表達式匹配的文本的信息,也不聲明每個匹配子串的位置。如果需要這些全局檢索的信息,可以使用RegExp.exec()

      let str6 = 'abcdea';
      str6.match(/a/g);
      // ["a", "a"]
      str6.match(/a/);
      // ["a", index: 0, input: "abcdea", groups: undefined]
      str6.match(/f/g);
      // null
    • String.prototype.replace(regexp, replacement):替換一個與正則表達式匹配的子串。

      let str7 = 'batfoocat';
      let a = str7.replace(/at/g, 'oo');
      // "boofoocoo"
      
      let b = str7.replace(/at/, 'oo');
      // "boofoocat"
      
      let c = str7.replace(/at/g, (value)=> {
          return  '!' + value;
      });
      // "b!atfooc!at"
    • String.prototype.split(separator [, howmany]):把一個字元串分割成字元串數組,第二個參數為可選,該參數可指定返回的數組的長度,不填則返回所有。

      let str8 = 'batfoocat';
      let a = str8.split(/at/g); // ["b", "fooc", ""]
      let b = str8.split(/at/); // ["b", "fooc", ""]
      let c = str8.split(/at/, 2); // ["b", "fooc"]
  5. 修飾符(標誌 - flags):

    • g:全局匹配,找到所有匹配,而不是在發現第一個匹配項後立即停止。

      let str9 = 'batfoocat';
      str9.match(/at/);
      // ["at", index: 1, input: "batfoocat", groups: undefined]
      str9.match(/at/g);
      // ["at", "at"]
    • i:忽略大小寫。

      let str10 = 'AabbccDD';
      str10.match(/a/gi); // ["A", "a"]
      str10.match(/a/g); // ["a"]
      str10.match(/A/g); // ["A"]
    • m:執行多行匹配,和^$搭配起來使用。

      多行; 將開始和結束字元(^和$)視為在多行上工作(也就是,分別匹配每一行的開始和結束(由 \n 或 \r 分割),而不只是只匹配整個輸入字元串的最開始和最末尾處。(mdn)

      `
      abc
      def
      `.match(/def/);
      // ["def", index: 5, input: "↵abc↵def↵", groups: undefined]
      
      `
      abc
      def
      `.match(/def/m);
      // ["def", index: 5, input: "↵abc↵def↵", groups: undefined]
      
      `
      abc
      def
      `.match(/^def$/);
      // null
      
      `
      abc
      def
      `.match(/^defc$/m);
      // ["def", index: 5, input: "↵abc↵def↵", groups: undefined]
    • u:Unicode 模式,可以正確處理碼點大於\uFFFF的 Unicode 字元。

      /\u{20BB7}/.test('
      
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • redis主從複製 Author:SimpleWu "GitHub redis" 什麼是主從複製? 主從複製,是用來建立一個和主資料庫(master)完全一樣的資料庫環境,稱為從資料庫(slave)。 主從複製的作用和使用場合一般有幾個: 一是容災恢復,主資料庫伺服器故障後,可迅速從從資料庫恢復。 ...
  • Redis的消息發佈和訂閱 Author:SimpleWu "GitHub redis" 什麼是消息發佈和訂閱? Redis 發佈訂閱(pub/sub)是一種進程間的消息通信模式: 發送者(pub)發送消息 訂閱者(sub)接收消息 Redis 客戶端可以訂閱任意數量的頻道。 但是一般不會使用red ...
  • 跳轉 命名路由 在文件構建時先設置路由參數: 在需要做路由跳轉的時候直接使用: 構建路由 區別 以上兩種路由的優缺點十分明顯: 1. 命名路由簡明並且系統,但是不能傳參。 2. 構建路由可以傳參,但比較繁瑣。 動畫 構建動畫 先在構建一個動畫效果,如: 以上動畫意思為跳轉時新頁面從右邊劃入,返回時向 ...
  • 這裡記錄兩個iOS開發中經常用到的知識點,一個是唯一標識,一個是全局變數。唯一標識一臺設備(比如iPhone、iPad等)是一個基本的實現與業務上的需求,因為這個唯一標識在許多場景都需要使用到,比如用來統計(日活、總用戶數等),再比如用作預設的賬號,等等。 ...
  • 平時在使用Vue框架的業務開發中,組件不僅僅要把模板的內容進行復用,更重要的是組件之間要進行通信。組件之間通信分為三種:父-子;子-父;跨級組件通信。下麵,就組件間如何通信做一些總結。 1.父組件到子組件通過props通信 在組件中,使用選項props來聲明需要從父級組件接受的數據,props的值可 ...
  • 在開發的過程中,遍歷是一個經常遇到的。而for迴圈則是Javascript工具箱里一個好用的,也常用的工具。每個人的習慣不同,for迴圈的寫法也不盡相同。 1、不寫聲明變數的寫法: 我們很多時候的寫法使這種(做小白不堪迴首的那些年),但這種寫法,每次都會獲取一下數組的長度,這會降低代碼的效率。 2、 ...
  • Vue源碼解析之nextTick 前言 nextTick是Vue的一個核心功能,在Vue內部實現中也經常用到nextTick。但是,很多新手不理解nextTick的原理,甚至不清楚nextTick的作用。 那麼,我們就先來看看nextTick是什麼。 nextTick功能 看看官方文檔的描述: 在下 ...
  • 摘要: 本插件基於layui.layedit,增加了HTML源碼模式,片插入功能添加alt屬性(layupload),視頻插入功能,全屏功能,段落格式,字體顏色設置,右鍵菜單操作,插入錨點,水平線功能。 所有拓展功能菜單按鈕圖標均引用自layui自帶圖標。 演示地址:kz.layedit 一、基礎拓 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...