1.\d,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^,$分別是什么?
\d——等價[0-9],數字字符類
\w——等價[a-zA-Z_0-9],單詞字符,字母、數字下劃線
\s——等價[\t\n\x0B\f\r],空白符
[a-zA-Z0-9]——創建了一個類,代表一個字符,該字符可以是a-zA-Z0-9中任意一個
\b——單詞邊界
.——除了回車符和換行符之外的所有字符,[^\r\n]
*——出現零次或多次(任意次)
+——出現一次或多次(至少出現一次)
?——出現零次或一次(最多出現一次)
x{3}——x出現3次
——結合[],可做取反使用[abc]不包含abc,也用作篩選字符串開頭,/^hello/,以hello開頭
$——/hello&/,以hello結尾
2.寫一個函數trim(str),去除字符串兩邊的空白字符
去除字符串開頭和結尾的空白字符
function trim(str){
var strBegin = /^\s+/;
var strEnd = /\s+$/;
var tempStr = str.replace(strBegin, '');
tempStr = tempStr.replace(strEnd, '');
return tempStr;
}
去除字符串中所有空白字符
function trim(str){
var reg = /\S+/g;
var result = '';
while(r=reg.exec(str)){
result += r[0];
}
return result;
}
3.寫一個函數isEmail(str),判斷用戶輸入的是不是郵箱
function isEmail(str){
var reg = /(^[a-zA-Z0-9])+[\w\.]+\w+@[a-zA-Z0-9]+\.\w+[a-zA-Z]$/;
return reg.test(str)
}
4.寫一個函數isPhoneNum(str),判斷用戶輸入的是不是手機號
function isPhoneNum(str){
var reg = /^1[0-9]{10}$/;
return reg.test(str);
}
5.寫一個函數isValidUsername(str),判斷用戶輸入的是不是合法的用戶名(長度6-20個字符,只能包括字母、數字、下劃線)
function isValidUsername(str){
var reg = /^\w\w{5,9}$/;
return reg.test(str);
}
6.寫一個函數isValidPassword(str), 判斷用戶輸入的是不是合法密碼(長度6-20個字符,只包括大寫字母、小寫字母、數字、下劃線,且至少包括兩種)
function isValidPassword(str){
var rule1 = /^\w\w{5,19}$/;
var rule2 = /\d+/;
var rule3 = /[a-z]+/;
var rule4 = /[A-Z]+/;
var rule5 = /_+/;
var resultSum = rule2.test(str) + rule3.test(str) + rule4.test(str) + rule5.test(str);
return (rule1.test(str) && (resultSum >= 2));
}
7.寫一個正則表達式,得到如下字符串里所有的顏色
var re = /#[a-zA-Z0-9]{6}/g;
var subj = "color: #121212; background-color: #AA00ef; width: 12px; bad-colors: f#fddee "
console.log( subj.match(re) ) // ['#121212', '#AA00ef']
8.下面代碼輸出什么? 為什么? 改寫代碼,讓其輸出[""hunger"", ""world""].
var str = 'hello "hunger" , hello "world"';
var pat = /".*"/g;
str.match(pat);
因為貪婪模式,盡可能多的匹配,加上?,盡可能少的匹配
var str = 'hello "hunger" , hello "world"';
var pat = /".*?"/g;
str.match(pat);