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