1: \d箕母,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^,$分別是什么?
\d:數(shù)字字符
\w:單詞字符剑梳,字母、數(shù)字下劃線
\s:空白符
[a-zA-Z0-9]:代表一個字符范圍在a到z,A到Z猎塞,0到9
\b:單詞邊界
.:除了回車符和換行符之外的所有字符
*:出現(xiàn)任意次數(shù)
+:出現(xiàn)一次或者多次(至少出現(xiàn) 一次)
?:出現(xiàn)零次或一次(最多出現(xiàn) 一次)
x{3}:x出現(xiàn)3次
^:在中括號里叫取反,沒有中括號在"http://"里叫以xxx開頭
$:以xxx結(jié)尾
2: 寫一個函數(shù)trim(str)杠纵,去除字符串兩邊的空白字符
function trim(str){
return str.replace(/^\s+|\s+$/g,'')
}
3: 寫一個函數(shù)isEmail(str)荠耽,判斷用戶輸入的是不是郵箱
function isEmail(str){
var reg = /^\w+@\w+\.[a-zA-Z]+$/
return reg.test(str)
}
4: 寫一個函數(shù)isPhoneNum(str),判斷用戶輸入的是不是手機號
function isPhoneNum(str){
return /^1\d{10}$/.test(str)
}
5: 寫一個函數(shù)isValidUsername(str)淡诗,判斷用戶輸入的是不是合法的用戶名(長度6-20個字符骇塘,只能包括字母、數(shù)字韩容、下劃線)
function isValidUsername(str){
var reg = /^\w{6,20}$/
return reg.test(str)
}
6: 寫一個函數(shù)isValidPassword(str), 判斷用戶輸入的是不是合法密碼(長度6-20個字符款违,只包括大寫字母、小寫字母群凶、數(shù)字插爹、下劃線,且至少至少包括兩種)
function isValidPassword(str){
if(!/^\w{6,20}$/.test(str)) return false;
if(/^[A-Z]{6,20}$/.test(str)) return false;
if(/^[a-z]{6,20}$/.test(str)) return false;
if(/^_{6,20}$/.test(str)) return false;
if(/^\d{6,20}$/.test(str)) return false;
else return true;
}
isValidPassword('_123ABDa')
//true
7: 寫一個正則表達式请梢,得到如下字符串里所有的顏色
var subj = "color: #121212; background-color: #AA00ef; width: 12px; bad-colors: f#fddee "
var reg = /#[0-9a-fA-F]{6}(?=;)|#[0-9a-fA-F]{3}(?=;)/g
//或者var reg = /#([0-9a-fA-F]{6}|[0-9a-fA-F]{3})(?=;)/g
console.log( subj.match(reg) ) // ['#121212', '#AA00ef']
8: 下面代碼輸出什么? 為什么? 改寫代碼赠尾,讓其輸出[""hunger"", ""world""].
var str = 'hello "hunger" , hello "world"';
var pat = /".*"/g;
str.match(pat);
//[""hunger" , hello "world""],瀏覽器默認是貪婪模式毅弧,把hello"也算入
var str = 'hello "hunger" , hello "world"';
var pat = /".*?"/g;
str.match(pat);
//[""hunger"", ""world""]气嫁,改為非貪婪模式