js誕生的目的是什麼?
就是為了做表單驗證。
在js未出現以前,表單的資訊驗證需要傳輸給後台,讓後台做資料驗證處理之後,再返回給前端頁面處理的結果。在頻寬有限的情況下,整個驗證過程非常複雜,且耗時。
1如果使用正則的方式:var str = "
asd68asd687as6da78sd123123zcacas"2
var linshi='';3
var arr=
4for(var i = 0 ; i < str .length ; i ++)else11}
12}13if(linshi!=''
)16 console.log(arr)
var arr = str.match(/\d+/g);
就可以完成功能
正規表示式(regular expression)是乙個描述字元規則的物件。可以用來檢查乙個字串是否含有某個字元,將匹配的字元做替換或者從某個字串中取出某個條件的子串等。
正則的建立方式:
1.建構函式方式
var reg1 = new regexp("a");
var str = "adassdfsd";
console.log(str.match(reg1)) //輸出匹配a的字元
2.字面量方式
var reg2 = /a/;
console.log(str2.match(reg2)); //輸出匹配a的字元
/ / 是正規表示式的識別符號
" " 是字串的識別符號
[ ] 是陣列的識別符號
是物件的識別符號
正則中的修飾符,寫在正規表示式後面/的後面:
g表示全域性匹配,查詢所有
i表示忽略大小寫
正則的驗證:
var reg = /[0-9]/;
reg.test(str) //返回為true表示驗證成功,false表示失敗
字串的replace函式的功能:將老字串替換成新字串
可以利用此函式,將老字串表示成正規表示式,對字串進行替換
如:字串中的abc替換成「哈哈」,如果正則後面沒有g,則只替換乙個,如果沒有i,則大寫不會替換
var str = 「abc123abc456abbcdabcefaacbcdbcabc";
var reg = /abc/g;
console.log(str.replace(reg,"哈哈"));
字串match函式的功能:提取所有的想要的東西
返回乙個陣列,包含所有符合條件的字元
\d 匹配所有的數字
var reg = /\d/g;
console.log(str.match(reg)) //列印字串中所有的數字
+ 若干,量詞,表示多少個都可以,至少1個,無上限
var reg = /\d+/g;
console.log(str.match(reg)) //列印字串中所有的數字,連續
| 或,類似於js中的 ||
var reg = /abc|bbc|cbc|dbc/g
console.log(str.match(reg)); //列印字串中的abc,bbc,cbc,dbc
var reg = /[a-c]bc/g
[ ] 中元符
var reg = /[a-z]/ //匹配所有字母
[0-9] == \d
^ 排除(除了)
var reg = /[^0-9]/ //表示除了數字之外所有
. 代表所有,不建議使用
var reg = /<.>/g
console.log(str.replace(reg,"")) //過濾,表示尖括號裡面的東西不要,但是?
正則的貪婪定律:
var reg = /]+>/g
console.log(str.replace(reg,"」)) //表示尖括號裡面的東西不要,真
轉義字元:
\d —— [0-9] 數字
\w —— [a-z0-9_] 數字,字母,下劃線
\s —— 空白字元(空格)
\d —— [^0-9] 非數字
\w —— [^a-z0-9_] 非數字,字母,下劃線
\s —— 非空白字元
量詞:限定符,可以指定正規表示式的乙個給定組,必須要出現多少次才能滿足匹配
* 匹配前面的子表示式零次或多次
+ 匹配前面的子表示式至少一次或多次
? 匹配前面的子表達是零次或一次
匹配確定n次
至少匹配n次
至少匹配n次,最多匹配m次
注:在限定符後緊跟?,則由貪婪匹配變成非貪婪匹配
qq號驗證規則:
var reg =/[1-9]\d/
固化的規則:0411-6666888
開頭為0或者2的或者三位數字加上-開頭為非零的八位數字,結尾是1到4的分機號
var reg = /(0\d-)?[1-9]\d(-\d)?/
複雜郵箱的規則:英文數字下劃線@一串英文或數子.一串英文
var reg = /\w+@[a-z0-9]+\.[a-z]+/i
想要校驗怎麼辦?在正則轉義字元前加上\
1.中文檢測
unicode編碼中文監測:/^[\u2e80-\u9fff]+$/
2.使用者名稱檢測
正則:/^[a-z0-9_-]$/
3.郵箱檢測
/^([a-z0-9_\.-]+)@([\da-z\.-]+)\.([a-z\.])$/
可以多次出現 (字母數字下劃線.-)@可以出現多個(數字字母.-).2到6位字母或.
/^[a-z\d]+(\.[a-z\d]+)*@([\da-z](-[\da-z])?)+(\.[a-z]+)+$/
可以有多個(字母數字)可有多個可無(.多個(字母數字))@可以多個(數字字母可 有1次可無(-數字字母))可以有多個(1或2個.多個字母)
4.url檢測
有1次或0次(http有1次或0次s : //) 可以多個(數字字母.-) . 2到6位(字母.) 可多個或0個 (可以多個或0個 /數字字母下劃線.-) 可0或1次/
5.html標籤檢測
/^(.*)|\s+\/>)$/
《多個(字母)可多個或0個(除了《的所有字元) />
《多個(字母)可多個或0個(除了《的所有字元)>多個任意字元
自定義的html標籤
正規表示式詳解
正規表示式 基本正規表示式主要用於grep,egrep,vi,sed,awk命令中進行字串匹配。符號 意義 c 匹配字母c 匹配任意單個字元 匹配前乙個字元出現零次或多次 匹配任意多個任意字元 匹配集合中的任意單個字元,括號中為乙個集合 x y 匹配連續的字串範圍 匹配字串的開頭 匹配字串的結尾 匹...
正規表示式詳解
正規表示式主要作用 分割 匹配 查詢 替換 正規表示式中包括的元素 1.原子 普通字元 a z a z 0 9 原子表 轉義字元 2.元字元 有特殊功能的字元 3.修正模式符 系統內建部分字元,例如 i m s u 原子 1.a z a z 0 9 最常見的字元 2.abc 用圓括號包含起來的單元符...
正規表示式詳解
正規表示式 regular expression 又稱正規表示式 規則表示式等,是電腦科學的乙個概念。正規表示式使用單個字串來描述 匹配一系列匹配某個句法規則的字串,也通常用來檢索 替換那些匹配某個模式的文字。下面從以下方面開始講述正規表示式在python中的應用。1.在python中使用,首先需要...