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
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...