正則的定義
字元出現的規律的一種規則!
正則的作用
驗證和查詢
建立正則
1、var reg=/輸入正則規則/; 注意:/ /內部是正則的天下,不支援js語法!
2、var reg=ner RegExp(); //瞭解即可,不需要強記!
正則的語法
1、關鍵詞的原文就是最簡單的正則
2、字符集:一個字元可能出現的備選字元的集合
eg::政[治法協]匹配:政治 政法 政協
常見字符集:如果備選字元的Unicode編碼是連續的,可以省略中間的字元,用“-”連結
eg:[0123456789]<=>0-9 [abcdefg]<=>[a-g]
預定字符集:預先已經規定好的字符集
eg:\w:一個字母數字下劃線 \d一個數字[0-9]
\s空格,製表符
.任意字元
^除了xxx
量詞:修飾一個字符集出現的次數!
1、有明確的數量要求或者範圍
字符集{m,n} m:表示字符集出現的最小次數! n:表示字符集出現的最大次數!
字符集{m}:至少出現m次,至多不限!
字符集{m}:只能必須是m次
2、沒有明確的數量要求
字符集?:可有可無,至多一次。等價於{0,1}
字符集+:至多一次,多了不限。等價於{1,}
字符集*:可有可無,次數不限。等價於{0,}
注意:如果正則規則中有特殊含義的字元,可以使用轉義字元"\"
選擇和分組
1、選擇:在多個規則之間任選其一都可以匹配!
操作:規則1|規則2:只要有一個規則適用即可!
2、分組:將多個規則分為一組,由一個量詞修飾!
操作:()eg:(+86 10086)? eg:(微/w(ei)?) (信/x(in)?)
匹配指定位置
1、開頭:^ ^\s以空格開頭
2、結尾:$ \s$以空格結尾
eg:^\d{6}:以六位數字開頭
\d{6}$:以六位數字結尾
^\d{6}$:字串只能是六位數字組成
3、單詞邊界:\b
eg:no\b 匹配以no結尾的單詞
\bno 匹配以no開頭的單詞
\bno\b 匹配完整的單詞no
案例:
1、身份證 340881199812120827
18位身份證號碼的驗證規則:^(\d{17}[0-9xX])$
或15位數字+2位數字+一位數字或者X或者x:^\d{15}(\d{2}[0-9Xx])?$
2、手機號: 6085255 解析:0086|+86 空格 | 6085255 9位數
9位數號碼的驗證規則:^(0086|86)?\s*|[6085255]\d[{9}$
字串的API
1、查詢敏感詞
0.查詢關鍵詞的下標----固定的敏感詞
var i=str.indexOf("關鍵詞",starti);
從starti位置開始向後找最近的一個關鍵詞的下標,找到就返回其下標,找不到返回-1。
1.判斷是否包含敏感詞----模糊查詢
str.search(/正則/);
//找第一個關鍵詞的下標,找到就返回其下標,找不到返回-1。
2.查詢所有敏感詞內容----返回陣列內容
str.match(/正則/g);
問題:1>預設正則只要匹配到一個關鍵詞就下標了!
解決:在正則的第二個/後g global
2>正則預設區分大小寫
解決:在正則的第二個/後加i ignore
3.既查詢敏感詞內容又查詢敏感詞位置----正則物件
reg.exec();----正則物件中的
2、替換:將符合要求的關鍵詞替換為指定內容
1.簡單替換
str.replace(/正則/g,"需要替換的新值");
注意:此處替換的新值是固定的!
2.高階替換
function kws (key) {
key.length==2?return"**":
key.length==3?return"***":
return"*"
}
str.replace(/正則/g,kws);
注意:replace方法每找到一個關鍵詞,會呼叫一次回撥函式,將關鍵詞傳入,由回撥函式替代的值!
3、切割:split 將字串按指定的關鍵詞切割為多個子字串,放在一個陣列返回!
1.簡單切割:var arr=str.split("切割符");
2.複雜切割:var arr=str.aplit(/正則/);
常用套路:var arr=str.aplit(" ");
相反操作:var str=arr.join(" ");
正則物件
1、RegExp物件:封裝了一條正則規則,提供了操作正則驗證、或查詢API的一類物件!
2、建立正則物件:
1.直接量:var reg=/正則/ig;
問題:此方法正則一旦建立,無法通過Js直接修改
2.用new
var reg=new RegExp("正則","ig");
優點:正則是字串形式,可以使用js語法!
RegExp的API
1、驗證字串格式
var bool=reg.test(str);
驗證字串是否符合正則規則,返回bool
可以直接當作判斷條件
驗證必需前加^後加$
2、既查詢關鍵詞內容又查詢關鍵詞位置
reg.exec(str);
查詢str中下一個關鍵詞的位置和內容,返回一個陣列
0:關鍵詞的內容 index:關鍵詞的位置
注意:預設第一次查詢從0號位置開始;以後每執行一次,都從上一次結束的位置之後***開始;找不到就返回null。
完結!