题目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){
var reg=/^\s+|\s+$/g;
return str.replace(reg, '');
}
trim(' a2333333f422cdefghiklm '); //'a2333333f422cdefghiklm'
题目3: 写一个函数isEmail(str),判断用户输入的是不是邮箱
function isEmail(str){
var reg = /^[a-zA-Z]\w+@\w+\.[a-zA-Z]+$/;
return reg.test(str);
}
题目4: 写一个函数isPhoneNum(str),判断用户输入的是不是手机号
function isPhoneNum(str){
var reg = /(\+86)?1(3\d|4[579]|5[0-35-9]|7[0135-8]|8\d)\d{8}/;
return reg.test(str);
}
题目5: 写一个函数isValidUsername(str),判断用户输入的是不是合法的用户名(长度6-20个字符,只能包括字母、数字、下划线)
function isValidUsername(str){
var reg = /^\w{6,20}$/;
return reg.test(str);
}
题目6: 写一个函数isValidPassword(str), 判断用户输入的是不是合法密码(长度6-20个字符,只包括大写字母、小写字母、数字、下划线,且至少至少包括两种)
function isValidPassword(str){
if(/^W+/.test(str)) return false;
var reg = /((?=.*\d)(?=.*\D)|(?=.*[a-zA-Z])(?=.*[^a-zA-Z]))^.{6,20}$/;
return reg.test(str);
}
题目7: 写一个正则表达式,得到如下字符串里所有的颜色
var re = /#[0-9A-Fa-f]{6}/g;
var subj = "color: #121212; background-color: #AA00ef; width: 12px; bad-colors: f#fddee
#fd2 "
alert( subj.match(re) ) // #121212,#AA00ef
题目8: 下面代码输出什么? 为什么? 改写代码,让其输出[""hunger"", ""world""].
var str = 'hello "hunger" , hello "world"';
var pat = /".*"/g; str.match(pat); //输出["hunger" , hello "world"]
//原因:量词在默认下是尽可能多的匹配的,也就是大家常说的贪婪模式,此模式下会尽可能多的匹配
//==========================
//修改目的:输出['hunger', 'world']
var req = /".*?"/g; //在量词后面加个?,就是非贪婪模式,该模式会尽可能少的匹配
str.match(req); //['hunger', 'world']