\d,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^,$分別是什么?
\d 匹配數(shù)字 \w 匹配字母或數(shù)字或下劃線或漢字 \s 匹配任意的空白符 等價于[\t\n\x0B\f\r]
[a-zA-Z0-9] 匹配范圍中的一個字符 \b 匹配單詞的開始或結(jié)束
. 匹配任意字符 * 出現(xiàn)零次或多次 +出現(xiàn)一次或多次 ? 出現(xiàn)零次或一次
x{3} x重復(fù)出現(xiàn)3次 ^ 以xx開始 若放在[]里取反 $ 以xx結(jié)尾
寫一個函數(shù)trim(str),去除字符串兩邊的空白字符
function trim(str){
return str.replace(/^\s+|\s+$/g,'')
}
寫一個函數(shù)isEmail(str),判斷用戶輸入的是不是郵箱
function isEmail(str){
var reg = /^\w+@\w+.com$/
return reg.test(str)
}
寫一個函數(shù)isPhoneNum(str),判斷用戶輸入的是不是手機(jī)號
function isPhoneNum(str){
var reg = new RegExp('^1\d{10}$')
return reg.test(str)
}
寫一個函數(shù)isValidUsername(str),判斷用戶輸入的是不是合法的用戶名(長度6-20個字符,只能包括字母、數(shù)字、下劃線)
function isValidUsername(str){
return /^\w{6,10}$/.test(str)
}
寫一個函數(shù)isValidPassword(str), 判斷用戶輸入的是不是合法密碼(長度6-20個字符,只包括大寫字母、小寫字母、數(shù)字、下劃線,且至少至少包括兩種)
function isValidPassword(str){
if(!/^\w{6,20}$/.test(str)) return false
if(/^\d{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
else return true
}
寫一個正則表達(dá)式,得到如下字符串里所有的顏色
var re = /:\s#([0-9a-fA-F]{6}|[0-9a-fA-F]{3})/g
var subj = "color: #121212; background-color: #AA00ef; width: 12px; bad-colors: f#fddee "
console.log( subj.match(re) ) // ['#121212', '#AA00ef']
下面代碼輸出什么? 為什么? 改寫代碼,讓其輸出[""hunger"", ""world""].
var str = 'hello "hunger" , hello "world"';
var pat = /".*"/g;
str.match(pat);
輸出 ""hunger" , hello "world""
因?yàn)?正則表達(dá)式從"開始 .為除換行符回車符外任意字符重復(fù)0次或多次 由于貪婪模式會盡可能的多匹配 so輸出上面的字符串
var newPat = /".*?"/g
在量詞后加? 改為非貪婪模式