1眶掌、匹配方法
RegExp
exec
/ab+c/.exec('abbcjhuohuoabcjhih')
// ["abbc", index: 0, input: "abbcjhuohuoabcjhih", groups: undefined]
test 返回true or false
String方法
match: 當reg沒有g的時候和exec一樣,當有g的時候直接返回匹配數(shù)組
replace
search:返回索引
split
- 創(chuàng)建正則
// pattern/flags
const regex = /ab+c/;
const regex = /^[a-zA-Z]+[0-9]*\W?_$/gi;
// new RegExp(pattern [, flags])
let regex = new RegExp("ab+c");
let regex = new RegExp(/^[a-zA-Z]+[0-9]*\W?_$/, "gi"); // 斜杠
let regex = new RegExp("^[a-zA-Z]+[0-9]*\\W?_$", "gi"); // 引號号杠,多了轉義字符
2、一些符號
- i不區(qū)分大小寫
- g 全局匹配
- () 匹配
'bar foo'.replace( /(...) (...)/, '$2 $1' )
var reg = /(\w+)\s(\w+)/;
var str = "John Smith";
var newstr = str.replace(reg, "$2, $1");
console.log(newstr); // Smith, John
- [] [a-z] 任意一個
- {} {3丰歌,4} 表示次數(shù)姨蟋,3到4次;\d{3}連續(xù)三個數(shù)字
- \w 數(shù)字字母下劃線,等價于[A-Za-z0-9_]
- \W 等價于[^A-Za-z0-9_],匹配 "50%." 中的 %
當 '^' 作為第一個字符出現(xiàn)在一個字符集合模式時,它將會有不同的含義'%'立帖。大寫就是反的眼溶。 - \d 數(shù)字
* //0個或以上,等價于{0,}
+ //一個或以上晓勇,等價于{1,}
? // 等價于{0,1}
let str = '123abc'
貪婪(盡可能匹配多的字符串):應用 /\d+/ 將會返回 "123"
非貪婪:使用 /\d+?/,那么就只會匹配到 "1"
.(小數(shù)點)匹配除換行符之外的任何單個字符
3堂飞、零寬斷言
(?=exp) //正先行斷言 匹配后綴前的
[a-z]*(?=ing) 匹配 cooking ,singing 绑咱,doing中除了ing之外的內(nèi)容绰筛,只取cook, sing, do的內(nèi)容
(?<=exp) //正后發(fā)斷言 匹配前綴后的
(?<=abc).* 可以匹配 abcdefgabc 中的 defgabc 而不是 abcdefg
(?!exp) //反先行斷言
(?<!exp) //反后發(fā)斷言
image.png
4、注意事項
- \b 匹配一個零寬單詞邊界(zero-width word boundary)描融,如一個字母與一個空格之間铝噩。 (不要和 [\b] 混淆)
例如,/\bno/ 匹配 "at noon" 中的 "no"稼稿,/ly\b/ 匹配 "possibly yesterday." 中的 "ly"薄榛。 - ^ 單獨出現(xiàn)是開始標志讳窟,和字母組合是補集的意思
5、小括號()捕獲
- exec 返回的數(shù)組arr[0]完整匹配敞恋。后面1234分別匹配1234個括號
-
9
var str = 'hello world';
var pattern = /([a-z]+)\s([a-z]+)/;
pattern.test(str); //這個地方必須運行正則匹配一次丽啡,方式不限,可以是test()硬猫、exec()补箍、以及String的正則方式
console.log(RegExp.$1) //'hello' 第一個分組([a-z]+)的值
console.log(RegExp.$2) //'world' 第二個分組([a-z]+)的值
var n_str = RegExp.$2+' '+RegExp.$1;
console.log(n_str) //world hello
7、非捕獲(?: 表達式)
//先看用捕獲性分組匹配會返回什么
var str1 = '000aaa111';
var pattern = /([a-z]+)(\d+)/; //捕獲性分組匹配
var arr = pattern.exec(str1);
console.log(arr) //['aaa111','aaa','111'] 結果子串也獲取到了啸蜜,這并不是我們想要的結果
//非捕獲性分組
var str2 = '000aaa111';
var pattern2 = /(?:[a-z]+)(?:\d+)/; //非捕獲性分組匹配
var arr2 = pattern.exec(str2);
console.log(arr2) //['aaa111'] 結果正確
8坑雅、如果正則中有變量,用new來構造
var reg = new RegExp(`${x}`,'g')
實例
1-判斷郵箱
reg=/^(\w)+(\.\w+)*@(\w)+(\.\w+)+$/;
2-輸入'rgb(255, 255, 255)'衬横,輸出#ffffff
return sRGB.replace(/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/g,function(a,b,c,d){ //a是原字符串裹粤,bcd是圓括號匹配到的數(shù)字
return '#'+hex(b)+hex(c)+hex(d);
function hex(n){
return n<16? '0'+(+n).toString(16) : (+n).toString(16); } })
3- -webkit-border-image 轉成webkitBorderImage
return sName.replace(/\-[a-z]/g,function(s,i){ //i為每次匹配到的字符
return i==0? s.replace("-",""): s.replace("-","").toUpperCase();
});
4-提取數(shù)字
var a='(2 -> 4 -> 3)'
b=a.match(/\d/g)
/*是否帶有小數(shù)*/
function isDecimal(strValue ) {
var objRegExp= /^\d+\.\d+$/;
return objRegExp.test(strValue);
}
/*校驗是否中文名稱組成 */
function ischina(str) {
var reg=/^[\u4E00-\u9FA5]{2,4}$/; /*定義驗證表達式*/
return reg.test(str); /*進行驗證*/
}
/*校驗是否全由8位數(shù)字組成 */
function isStudentNo(str) {
var reg=/^[0-9]{8}$/; /*定義驗證表達式*/
return reg.test(str); /*進行驗證*/
}
/*校驗電話碼格式 */
function isTelCode(str) {
var reg= /^((0\d{2,3}-\d{7,8})|(1[3584]\d{9}))$/;
return reg.test(str);
}
/*校驗郵件地址是否合法 */
function IsEmail(str) {
var reg=/^\w+@[a-zA-Z0-9]{2,10}(?:\.[a-z]{2,4}){1,3}$/;
return reg.test(str);
}