題目1:
\d,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^,$分別是什么?
-
\d表示數(shù)字,等價(jià)[0-9] -
\w表示字符、字母、數(shù)字、下劃線,等價(jià)[a-zA-Z_0-9] -
\s表示空白符,等價(jià)[\t\n\x0B\f\r] -
[a-zA-Z0-9]表示小寫字母、大寫字母、數(shù)字 -
\b表示單詞邊界 -
.表示除了回車符、換行符之外的所有字符,等價(jià)[^\r\n] -
*表示 0 次或多次,等價(jià){0,} -
+表示 1 次或多次,等價(jià){1,} -
?表示 0 次或 1 次,等價(jià){0,1} -
x{3}表示 xxx,即 x 出現(xiàn)3次 -
^表示開頭 -
$表示結(jié)尾
題目2:
寫一個(gè)函數(shù)trim(str),去除字符串兩邊的空白字符
function trim(str){
return str.replace(/^\s+|\s+$/g,"");
}
var str = " che ng ong ";
trim(str); // "che ng ong"
題目3:
寫一個(gè)函數(shù)isEmail(str),判斷用戶輸入的是不是郵箱
function isEmail(str){
var reg = /^[\w|-]+@\w+\.com$/;
return reg.test(str);
}
var str = "chengong-123@163.com";
isEmail(str); // true
題目4:
寫一個(gè)函數(shù)isPhoneNum(str),判斷用戶輸入的是不是手機(jī)號(hào)
function isPhoneNum(str){
var reg = /^(\+86)?-1[358]\d{9}$/;
return reg.test(str);
}
var str = "+86-13123456789";
isPhoneNum(str); // true
題目5:
寫一個(gè)函數(shù)isValidUsername(str),判斷用戶輸入的是不是合法的用戶名(長(zhǎng)度6-20個(gè)字符,只能包括字母、數(shù)字、下劃線)
function isValidUsername(str){
var reg = /^\w{6,20}$/;
return reg.test(str);
}
var str = "chengong_jirengu"
isValidUsername(str) // true
題目6:
寫一個(gè)函數(shù)isValidPassword(str), 判斷用戶輸入的是不是合法密碼(長(zhǎng)度6-20個(gè)字符,只包括大寫字母、小寫字母、數(shù)字、下劃線,且至少包括兩種)
function isValidPassword(str){
var reg = /^\w{6,20}$/;
if( reg.test(str)===false ){
return false;
}else if( /^[A-Z]{6,20}$/.test(str)===true ){
return false;
}else if( /^[a-z]{6,20}$/.test(str)===true ){
return false;
}else if( /^\d{6,20}$/.test(str)===true ){
return false;
}else if( /^-{6,20}$/.test(str)===true ){
return false;
}else{
return true;
}
}
isValidPassword("Chengong_jirengu123") // true
isValidPassword("chengong") // false
---------------這種方法不好,如果至少包括3種,4種就麻煩了,換下面這種方法--------------
function isValidPassword(str){
var reg = /^\w{6,20}$/;
var count = 0;
if(/[A-Z]/.test(str)){
count++;
}
if(/[a-z]/.test(str)){
count++;
}
if(/[0-9]/.test(str)){
count++;
}
if(/_/.test(str)){
count++;
}
return (count>=2 && reg.test(str));
}
isValidPassword("Chengong_jirengu123"); // true
isValidPassword("chengong"); // false
題目7:
寫一個(gè)正則表達(dá)式,得到如下字符串里所有的顏色
var re = /#[0-9a-fA-F]{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);
/* [""hunger" , hello "world""]
默認(rèn)情況是貪婪模式,符合條件的.*最大范圍是hunger" , hello "world
*/
var pat2 = /".*?"/g
str.match(pat2)
// [""hunger"", ""world""] 改成非貪婪模式