JavaScript正則表達式入門

来源:http://www.cnblogs.com/jecyu/archive/2017/09/10/7492848.html
-Advertisement-
Play Games

JavaScript正則表達式入門 ===================== 常常用戶在一個網頁里登錄註冊帳號時,要輸入用戶名、手機號、郵箱地址、設置密碼等項目。而對於用戶輸入的用戶名是否規範,輸入的是否是郵箱地址、密碼強度如何等等都可以通過一 正則表達式 制定相應的規則來驗證校檢,來實現一個非常 ...


JavaScript正則表達式入門

常常用戶在一個網頁里登錄註冊帳號時,要輸入用戶名、手機號、郵箱地址、設置密碼等項目。而對於用戶輸入的用戶名是否規範,輸入的是否是郵箱地址、密碼強度如何等等都可以通過一正則表達式制定相應的規則來驗證校檢,來實現一個非常複雜的業務邏輯。

在編寫處理字元串的程式或網頁時,經常有查找符合某些特定規則的字元串的需要。正則表達式就是用於描述這些規則的工具。正則表達式英文全稱為(Regular Expression),

創建正則表達式

  • 使用正則表達式字面量

    // 語法: /pattern/flag
    const reg = /at/g; // g可選,代表全局模式,匹配所有含有"at"的字元串
  • 使用RegExp對象構造函數,可以實現正則表達模式隨時改變,適用於必須在運行時動態生成正則表達式的情形,如用戶輸入

    // 語法: new RegExp(pattern [, flags]) 
    let regex = new RegExp('ab+c', 'g');
    let regex = new RegExp(/.at/gi);
    
    // str為用戶要查詢的值,trim()用於去除字元串的前置和後置空格
    let str = document.getElementById('u-input').value.trim(); 
    let re = new RegExp(str, 'g');

正則表達式語法

正則表達式必須寫在一行中,因為它們不支持註釋和空白

一個用來匹配URL的正則表達式如下:

var parseUrl = /^(?:([A-Za-z]+):)?(\/{0,3})([0-9.\-A-Za-z]+)(?::(\d+))?(?:\/([^?#]*))?(?:\?([^#]*))?(?:#(.*))?$/;  

var url = "http://www.ora.com:80/goodparts?q#fragment";

var result = parseUrl.exec(url); 
// exec()方法成功匹配字元串的話,則返回一個字元串片段組成的數組

正則表達式對應的結構圖(右鍵新標簽看大圖)

  • 正則表達式被包圍在一對斜杠//中,表示開始符和結束符。
  • 容器:() [] {}
    • ()一對括弧為一個捕獲組
    • []作為一個字元集合,匹配方括弧中的任意字元。
    • {}尾碼裡面的數字決定這個因數應該被匹配的次數,(/){0,3} 表示/會被匹配0次,或者1~3次。
  • 捕獲組與非捕獲型組
    • 捕獲型組 格式:(. . .)會複製它所匹配的文本,放到result數組裡。
    • 非捕獲型組 格式:(?: . . .) 只是匹配文本,不保存到result數組裡。如果不需要使用匹配後的文本,通常用非捕獲型來替代少量不優美的捕獲型分組,因為捕獲會有性能上的損失。
  • /^... $/
    • ^$分別置於模式的最前和最後,表示匹配字元串的開始和結束,保證開頭和結尾沒有多餘的內容。
  • ^在不同位置表示不同的意思。
    • 字元類[^?#]以^開始,表示這個類包含除?#外的所有字元。
    • 位於整個模式字元類的開頭,則表示此字元串的開始,只匹配那些從開頭就像該字元串(URL)一樣的字元串。
  • ?位於首碼和尾碼
    • 尾碼,如-?表示這個負號是可選的,(...)?表示這個分組是可選的
  • +*
    • 尾碼+表示匹配一個或多個,相當{1,}。
    • 尾碼*表示匹配0個或多個,相當{0,}。

更多特殊字元用法,見MDN正則表達式中的特殊字元

元字元

像上面闡釋那些具有特殊功能的字元

 / [ ] () { } ? + * | . ^ $

普通字元

除了元字元外,其他均是普通字元可以直接按字面處理使用,當然如果要使用元字元以及一些控制字元如 - (範圍像是A-Z,加上轉義可以當作負號來用) ,可以通過在其前面加上轉義\符號來去除它自身的特殊用途,即使其字面化。值得註意的是,\ 不能首碼不能使字母或數字字面化。

正則表達式筋骨脈絡圖

主體結構

分支

序列

因數

轉義

字元集

字元轉義

分組

量詞

兩個重要方法test()和exec()

regexp.exec(string)

exec()方法在一個指定字元串中搜索匹配,找到返回一個數組,並更新正則表達式兌現的屬性。返回的數組完全匹配成功的文本作為第一項,將正則括弧里匹配成功的作為數組填充到後面。匹配失敗則返回Null。如果只是為了判斷是否匹配,則可以使用RexExp.test()或者String.search()。

var matches = /hello \S+/.exec('This is a hello world!');
console.log(matches[0]);  // 'hello world!'

當rexExp帶有g標誌(全局搜索所有匹配的字元串)時,可以多次執行exec()查找所有匹配,即一個匹配模式在同一個字元串中發生了幾次。

regexp.test(string)

test()執行一個檢索,如果regexp與string,則返回true,否則返回false。
可用於if條件語句中

function testinput(re, str) {
    if(re.test(str)) {
        // 要執行的語句           
    } else {
        // 要執行的語句       
    }
}

一些例子

因為正則表達式是有關字元串的複雜規則的,所以字元串String的匹配、替換、查找等方法都可以傳入正則表達式作為參數,處理正則表達式的方法有regexp.exec、regexp.test、string.match、string.replace、string.search和string.split。

把String對象分割成字元串數組

需求:利用正則表達式分割用戶輸入的字元,允許一次批量輸入多個內容,格式可以為數字、中文、英文等,可以通過用回車,逗號(全形半形均可),頓號,空格(全形半形、Tab等均可)等符號作為不同內容的間隔

// 指定的分隔符
var re = /[-,,、.\s]+/g;  
// 也可以使用Unicode編碼表示 re = /[\u002c\uff0c\u3001\s]+/g;
// 可以聲明一個空的數組容器
var data = [];
  • 法一:RegExp.protype[@@split]()方法

    // 語法:str.split([separator[,limit]])
    
    // str為用戶輸入的值
    data = data.concat(str.split(re)); 
  • 法二:String.protype.split()

    // 語法:regexp[Symbo.split](str[,limit])
    
    data = data.concat(re[Symbol.split](str));

兩個方法的使用方法相同,只是this和參數順序不同。

使用正則表達式匹配實現輸入查詢

已知存在一個數組data,現在用戶輸入一個值來查詢是否存在某個字元串,匹配到且做一定標識(如顏色的改變)

  • 法一:使用正則表達式reg.test()方法,找到返回true,否則為false。

    data.forEach(function (element, index, array) {
        // str為用戶要查詢的值
        var re = new RegExp(str, 'g');
    
        // 匹配到的內容則改變背景顏色,沒有匹配到的則為預設顏色
        if (re.test(element.innerHTML)) {
            element.style.background = '#49b310';
            element.style.border = '1px solid #ccc';
        } 
        else {
            element.style.background = '#ff3f41';
        }
    }); 
  • 法二:使用字元串位置方法indexOf()lastIndexOf()方法,找到返回字串首次出現的下標,找不到則返回-1。

    if (data[index].indexOf(str) !== -1) { // 設置標識}

正則表達式之空格處理

(更多見維基百科:全形和半形

中文/英文輸入法下,按space鍵分別出全形空格和半形空格。使用轉義字元\s可以匹配任何空白符,它等同於[\f\n\r\t\u000B\u0020\u00A0\u2028\u2029],這是Unicode空白的一個不完全子集。

demo

總結

不要複製粘貼,杜絕死記硬背,誠心正意,自證良知,由外入里,層層剖析。
更詳細的回答見知乎:你是如何學會正則表達式的?

線上工具

拓展閱讀

參考資料


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

-Advertisement-
Play Games
更多相關文章
  • 響應式佈局 響應式佈局,簡而言之,就是一個網站能夠相容多個終端——而不是為每個終端做一個特定的版本。這個概念是為解決移動互聯網瀏覽而誕生的。 響應式佈局可以為不同終端的用戶提供更加舒適的界面和更好的用戶體驗,而且隨著目前大屏幕移動設備的普及,用“大勢所趨”來形容也不為過。隨著越來越多的設計師採用這個 ...
  • 1. nextSibling 屬性可返回某個節點之後緊跟的節點(處於同一樹層級中)。 語法: 說明:如果無此節點,則該屬性返回 null。 2. previousSibling 屬性可返回某個節點之前緊跟的節點(處於同一樹層級中)。 語法: 說明:如果無此節點,則該屬性返回 null。 註意: 兩個 ...
  • 如果js屬於剛剛入門階段,不建議抱著書一直看下去,因為這樣你不容易明白這些定義和概念的用法.看著看著就會很迷惑的。建議先試著用原生JS寫一些小項目和小程式,然後試著寫博客做些筆記,把遇到的困惑寫下來,帶著疑問去學習。 如果有一定的js基礎或者用JQuery等一些庫做過一些小東西的話,可以先看《Jav ...
  • bootstrap前端開發工具 柵格系統 版心 .container 柵格佈局 (一行分為12格,響應式佈局) .row .col md 12 .col sm 12 .col xs 12 排版 文本對齊: .text center; .text left; .text right; 塊標簽對齊: . ...
  • html文件 ...
  • 1 if (!Object.keys) { 2 Object.keys = (function () { 3 var hasOwnProperty = Object.prototype.hasOwnProperty, //原型上的方法,只取自身有的屬性; 4 hasDontEnumBug = !({... ...
  • 1.註釋: html的註釋:<!--我是註釋--> CSS的註釋:/*我是註釋*/ JS的註釋://我是註釋 2.變數: 變數要先聲明再賦值,如下: var mychar; mychar="javascript"; var mynum = 6; 變數可以重覆賦值,如下: var mychar; my ...
  • 任務 1.在第27行處補充完整,實現當點擊"全選"按鈕時,將選中所有的覆選項。 提示:document.getElementsByTagName("input")獲取的是所有input標簽,包括覆選項和按鈕,所以要判斷是否是覆選項,如是選中。 2.在第33行處補充完整,實現當點擊"全不選"按鈕時,將 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...