\d,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^,$分別是什么?
\d [0-9] 只匹配數字字符
\w [a-zA-Z_0-9] 匹配大小寫字母,數字下劃線
\s [\t\n\x0B\f\r] 空白符
[a-zA-Z0-9] 匹配大小寫字母和數字
\b 單詞邊界
. [^\r\n] 除了回車符和換行符之外的所有字符
? 表示某個元素出現零次或一次(最多出現一次)
x{3} 表示匹配某個元素,這個元素出現3次
^$ 匹配空字符串(空格一個也沒有的)
寫一個函數trim(str),去除字符串兩邊的空白字符
function trim(str) {
return str.replace(/(^\s*)|(\s*$)/g, '');
}
var str = ' 123 ';
console.log(trim(str))
console.log(str)
寫一個函數isEmail(str),判斷用戶輸入的是不是郵箱
function isEmail(str) {
var reg = /^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/;
return reg.test(str);
}
寫一個函數isPhoneNum(str),判斷用戶輸入的是不是手機號
function isPhoneNumber(str) {
return /^1\d{10}$/.test(str);
}
console.log(isPhoneNumber(15931887000))
console.log(isPhoneNumber(159318970000))
console.log(isPhoneNumber(13933324444))
寫一個函數isValidUsername(str),判斷用戶輸入的是不是合法的用戶名(長度6-20個字符,只能包括字母、數字、下劃線)
function isValidUsername(str) {
return /^\w{6,20}$/.test(str);
}
console.log(isValidUsername('123456'))
console.log(isValidUsername('sdacxzzce'))
console.log(isValidUsername('dsa12'))
寫一個函數isValidPassword(str), 判斷用戶輸入的是不是合法密碼(長度6-20個字符,只包括大寫字母、小寫字母、數字、下劃線,且至少至少包括兩種)
function isValidPassword(str){
var reg = /^\w{6,20}$/;
var count = 0;
if(! reg.test(str)){
return false;
}
if(/[a-z]/.test(str)){
count++;
}
if(/[A-Z]/.test(str)){
count++;
}
if(/\d/.test(str)){
count++;
}
if(/[_]/.test(str)){
count++;
}
return count>=2;
}
console.log(isValidPassword("1wwwWW_567"));
寫一個正則表達式,得到如下字符串里所有的顏色
var reg = /#([a-fA-F0-9]{6}|#[a-zA-F0-9]{3})(?=;)/g;
var subj = "color: #121212; background-color: #AA00ef; width: 12px; bad-colors: f#fddee ";
console.log( subj.match(reg) ) // ['#121212', '#AA00ef']
下面代碼輸出什么? 為什么? 改寫代碼,讓其輸出[""hunger"", ""world""].
var str = 'hello "hunger" , hello "world"';
var pat = /".*"/g;
str.match(pat); //""hunger" , hello "world""
var pat = / ".*? "/g
str.match(pat); //[""hunger"", ""world""]