\d静尼,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^,$分別是什么?
\d:數(shù)字
\w:數(shù)字,字母传泊,下劃線
\s:空白符
[a-zA-Z0-9]: 數(shù)字鼠渺、字母
\b:單詞邊界
*
:任意次
**+: **一次以上,包括一次
**?: **0或一次
.:除了回車(chē)符和換行符之外的所有字符
x{3}:xxx
**^: **在[]外面表示以某個(gè)字符開(kāi)頭眷细,在[]里面表示非
$:表示字以某個(gè)字符結(jié)尾
寫(xiě)一個(gè)函數(shù)trim(str)拦盹,去除字符串兩邊的空白字符
function trim(str) {
return str.replace( /^\s+|\s+$/g, '')
}
trim(' 434fgf '); //434fgf
trim(' 434fgf'); //434fgf
trim('434fgf '); //434fgf
trim(' 434 fgf '); //434 fgf
寫(xiě)一個(gè)函數(shù)isEmail(str),判斷用戶(hù)輸入的是不是郵箱
function isEmail(str) {
return /^\w+@[a-zA-Z0-9]+[.][a-z]{2,5}$/.test(str)
}
寫(xiě)一個(gè)函數(shù)isPhoneNum(str)溪椎,判斷用戶(hù)輸入的是不是手機(jī)號(hào)
function isPhoneNumber(str) {
return /1[34578]\d{9}$/.test(str);
}
寫(xiě)一個(gè)函數(shù)isValidUsername(str)普舆,判斷用戶(hù)輸入的是不是合法的用戶(hù)名(長(zhǎng)度6-20個(gè)字符,只能包括字母池磁、數(shù)字奔害、下劃線)
function isValidUsername(str) {
return /^\w{6,20}$/.test(str);
}
寫(xiě)一個(gè)函數(shù)isValidPassword(str), 判斷用戶(hù)輸入的是不是合法密碼(長(zhǎng)度6-20個(gè)字符,只包括大寫(xiě)字母地熄、小寫(xiě)字母华临、數(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 (/^\d{6, 20}$/.test(str)) return false;
if (/^_{6, 20}$/.test(str)) return false;
return true;
}
寫(xiě)一個(gè)正則表達(dá)式雅潭,得到如下字符串里所有的顏色(#121212)
var subj = "color: #121212; background-color: #AA00ef; width: 12px; bad-colors: f#fddee #fd2 ";
function colorReg(str) {
var reg = /\s#([0-9a-fA-F]{6}|[0-9a-fA-F]{3})/g;
var arr = str.match(reg);
for (var i = 0; i<arr.length; i++) {
arr[i] = arr[i].substr(1);
}
return arr;
}
console.log(colorReg(subj
下面代碼輸出什么? 為什么? 改寫(xiě)代碼揭厚,讓其輸出[""hunger"", ""world""].
var str = 'hello "hunger" , hello "world"';
var pat = /".*"/g;
str.match(pat);
//輸出:"hunger" , hello "world"
改成這樣:var pat = /".*?"/g; 變成非貪婪模式