1.\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} | 量词,x出现3次 |
^ | 边界匹配字符,以xxx开头;在中括号里面就是取反的意思 |
$ | 边界匹配字符,以xxx结尾 |
2.写一个函数trim(str),去除字符串两边的空白字符
function trim(str){
return str.replace(/^\s+|\s+$/g,'')
}
trim(" hello \n")
3.写一个函数isEmail(str),判断用户输入的是不是邮箱
function isEmail(str){
return /^\w+[@]\w+[.]\w+$/.test(str)
}
isEmail("156@qq.com")
4.写一个函数isPhoneNum(str),判断用户输入的是不是手机号
function isPhoneNum(str){
return /^1\d{10}$/.test(str);
}
isPhoneNum("123abc");
isPhoneNum("13687900000");
isPhoneNum("13687000000234");
5.写一个函数isValidUsername(str),判断用户输入的是不是合法的用户名(长度6-20个字符,只能包括字母、数字、下划线)
function isValidUsername(str){
return /^\w{6,20}$/.test(str);
}
isValidUsername("123_456-")
6.写一个函数isValidPassword(str), 判断用户输入的是不是合法密码(长度6-20个字符,只包括大写字母、小写字母、数字、下划线,且至少至少包括两种)
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;
}
isValidPassword("1_33a");
isValidPassword("123456");
isValidPassword("ASDFGHJ");
isValidPassword("abcdefg");
isValidPassword("1_33aA45");
7.写一个正则表达式,得到如下字符串里所有的颜色
var re = /#([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']
8.下面代码输出什么? 为什么? 改写代码,让其输出[""hunger"", ""world""].
var str = 'hello "hunger" , hello "world"';
var pat = /".*"/g;
str.match(pat);
输出结果: [""hunger", hello "world""]
"."除了回车符和换行符之外的所有字符,"*"出现零次或多次,量词在默认情况下会尽可能多的匹配。也就是贪婪模式。让正则表达式尽可能少的匹配,就是非贪婪模式,只需要在量词后面加上"?"即可
var str = 'hello "hunger" , hello "world"';
var pat = /".*?"/g;
str.match(pat);
输出结果:[""hunger"", ""world""]