1.\d,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^,$分別是什么?
- \d:數(shù)字
- \w:單詞字符、字母、數(shù)字下劃線
- \s:空白字符
- [a-zA-Z0-9]:大小寫字母和數(shù)字
- \b:單詞邊界
- .:所有字符
- *:出現(xiàn)任意次
- +:至少出現(xiàn)一次
- ?:最多出現(xiàn)一次
- x{3}:x字符出現(xiàn)3次
- ^:開頭
- $:結(jié)尾
2.寫一個(gè)函數(shù)trim(str),去除字符串兩邊的空白字符
function trim (str)
{
return str.replace(/^\s+|\s+$/g, '');
}
console.log(trim(' asdad 13 '));
3.寫一個(gè)函數(shù)isEmail(str),判斷用戶輸入的是不是郵箱
function isEmail (str)
{
var reg = /^\w+@[\w.-]+$/;
return reg.test(str);
}
console.log(isEmail('asdad@13.commands'));
4.寫一個(gè)函數(shù)isPhoneNum(str),判斷用戶輸入的是不是手機(jī)號(hào)
function isPhoneNum (str)
{
var reg = /^(\+86-)?1[356789]\d{9}/;
return reg.test(str);
}
console.log(isPhoneNum('17620378779'));
5.寫一個(gè)函數(shù)isValidUsername(str),判斷用戶輸入的是不是合法的用戶名(長度6-20個(gè)字符,只能包括字母、數(shù)字、下劃線)
function isValidUsername (str)
{
var reg = /\w{6,20}/;
return reg.test(str);
}
console.log(isValidUsername('n313893254'));
6.寫一個(gè)函數(shù)isValidPassword(str), 判斷用戶輸入的是不是合法密碼(長度6-20個(gè)字符,只包括大寫字母、小寫字母、數(shù)字、下劃線,且至少至少包括兩種)
function isValidPassword (str)
{
if (!(/\w{6,20}/.test(str)))
{
return false;
}
var cond = 0;
if (/[A-Z]/.test(str))
{
cond++;
}
if (/[a-z]/.test(str))
{
cond++;
}
if (/[0-9]/.test(str))
{
cond++;
}
if (/[_]/.test(str))
{
cond++;
}
if (cond >= 2)
{
return true;
}
else
{
return false;
}
}
console.log(isValidPassword('n313893254'));
7.寫一個(gè)正則表達(dá)式,得到如下字符串里所有的顏色
var re = /#[\dabcdef]{6}/gi
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;
console.log(str.match(pat));
//匹配兩個(gè)雙引號(hào)之間的內(nèi)容:[""hunger" , hello "world""]
var str = 'hello "hunger" , hello "world"';
var pat = /"[^"]*"/g;
console.log(str.match(pat));
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。