正規表示式

2022-07-24 06:30:16 字數 1964 閱讀 6493

物件:

內建物件:array function date math string number regexp boolean ...

宿主物件:dom bom

自定義物件

------------------

regexp:正則物件 (regular expression)

由普通字元和特殊字元構成的文字模式,該文字模式是用來檢測當前字串是否符合你的這套文字模式

是一種強大的字串匹配工具,如輸入驗證等場景

一 定義正則物件

var reg=new regexp("正規表示式","修飾符");---建構函式語法

var reg=/正規表示式/修飾符;---直接量語法

二 修飾符

i 不區分大小寫

g 全域性匹配

/[\w!#$%&'*+/=?^_`~-]+(?:\.[\w!#$%&'*+/=?^_`~-]+)*@(?:[\w](?:[\w-]*[\w])?\.)+[\w](?:[\w-]*[\w])?/

三 正規表示式的構成

1 元字元

\w:匹配數字字母下劃線

\w:匹配非數字字母下劃線

\d:匹配數字

\d:匹配非數字

\s:匹配空白字元

\s:匹配非空白字元

. :匹配換行和行結束符以外的任意字元

^ :匹配字串開始

$ :匹配字串的結束

\n:匹配換行符

2 方括號:用於查詢某個範圍內的字元

:匹配中羅列的單個字元

[abc]

[\u4e00-\u9fa5]

[a-z]

[a-z]

[0-9]<===>\d

[a-z0-9_]<===>\w /\w/i /[a-z0-9_]/i new regexp("[a-z0-9_]","i")

[^]:匹配除了當中羅列的字元以為的單個字元 [^abc] [^a-c]

3 限定符(量詞):用來描述字元出現的次數

? :匹配0個或1個

+ :匹配1個或多個

:匹配n個 /\d/ /[0-9]/

:匹配至少m個但是不能超過n個 /\d/

:匹配至少m個 + <===>

4 分組和選擇

() :分組 abcabcabc (abc)

| :選擇 aba abb aab bab aaa bbb... (a|b)

aabbbb aaaaaa bbbbbb bbaabb ... ((aa)|(bb))

6-18個字元構成,可以使用字母數字下劃線,但是必須以字母開頭

\w ^[a-z]

/^[a-za-z]\w$/ /^[a-z]\w$/i

手機號:

1 3/5/7/8

/^1[3578]\d$/

email:

sakjdakjd @ zhcfdh . com

\w+ @ [a-z]+ [.]或者\. (com)

/^\w+@[a-z]+\.(com)$/i

四 常用正規表示式的string物件的方法

string.search(reg):檢測與正規表示式相匹配的值,如果找到返回匹配的位置否則返回-1

string.match(reg):找到乙個或多個正規表示式的匹配,返回的是乙個集合

string.replace(reg):替換與正規表示式匹配的子字串

正規表示式在匹配的時候有乙個特性:貪婪

五 regexp物件的方法

regexp.test(string):用於對某個字串進行檢測,如果符合正規表示式的乙個匹配結果則返回true,否則就返回false

只要字串當中有一部分滿足正則的話就返回true,所以在書寫正則的時候必須要加上(^$)

正規表示式 正規表示式 總結

非負整數 d 正整數 0 9 1 9 0 9 非正整數 d 0 負整數 0 9 1 9 0 9 整數 d 非負浮點數 d d 正浮點數 0 9 0 9 1 9 0 9 0 9 1 9 0 9 0 9 0 9 1 9 0 9 非正浮點數 d d 0 0 負浮點數 正浮點數正則式 英文本串 a za z...

正規表示式 表示式

網域名稱 a za z0 9 a za z0 9 a za z0 9 a za z0 9 interneturl a za z s 或 http w w w 手機號碼 13 0 9 14 5 7 15 0 1 2 3 5 6 7 8 9 18 0 1 2 3 5 6 7 8 9 d 號碼 x x x...

Linux正規表示式 編寫正規表示式

為了所有實用化的用途,你可以通過使用程式產生正確的結果。然而,並不意味著程式總是如你所願的那樣正確地工作。多數情況下,如果程式不能產生想要的輸出,可以斷定真正的問題 排除輸入或語法錯誤 在於如何描述想要的東西。換句話說,應該考慮糾正問題的地方是描述想要的結果的表示式。表示式不完整或者公式表示得不正確...