题目1: \d,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^,$分别是什么?
\d : 数字字符
\w : 单词字符,字母、数字下划线
\s : 空白符
[a-zA-Z0-9] : 字母a到z(包含大小写),数字0到9
\b : 单词边界
. : 除了换行和回车之外的任意字符
* : 出现零次或多次(任意次)
+ : 出现一次或多次(至少一次)
? : 出现零次或一次
x{3} : 对应零次或者3次
^ : 开头
$ : 结尾
题目2: 写一个函数trim(str),去除字符串两边的空白字符
function trim(str) {
return str.replace(/^\s+|\s+$/g, '');
}
str = " aa bb cc ";
trim(str);
题目3: 写一个函数isEmail(str),判断用户输入的是不是邮箱
function isEmai(str) {
return /^(\w+)(\.\w+)*@(\w+)((\.\w+)+)$/.test(str);
}
str = "takb_666.glo@155.com";
isEmai(str);
题目4: 写一个函数isPhoneNum(str),判断用户输入的是不是手机号
function isPhoneNum(str) {
return /^(\+86)?1(3|4|5|7|8)[0-9]\d{8}$/.test(str);
}
题目5: 写一个函数isValidUsername(str),判断用户输入的是不是合法的用户名(长度6-20个字符,只能包括字母、数字、下划线)
function isValidUsername(str) {
return /^\w{6,20}$/.test(str);
}
题目6: 写一个函数isValidPassword(str), 判断用户输入的是不是合法密码(长度6-20个字符,只包括大写字母、小写字母、数字、下划线,且至少至少包括两种)
function isVaildPassword(str) {
if(str.length < 6 || str.length >20) return false;
if(/^[A-Z]+$/.test(str)) return false;
if(/^[a-z]+$/.test(str)) return false;
if(/^\d+$/.test(str)) return false;
if(/^_+$/.test(str)) return false;
return true;
}
题目7: 写一个正则表达式,得到如下字符串里所有的颜色
var re = /#[a-f0-9]{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;
str.match(pat); //贪婪模式从第一个双引号匹配到最后一个双引号 输出[""hunger" , hello "world""]
当正则表达式中包含能接受重复的限定符时,通常的行为是(在使整个表达式能得到匹配的前提下)匹配尽可能多的字符。以这个表达式为例:a.b,它将会匹配最长的以a开始,以b结束的字符串。如果用它来搜索aabab的话,它会匹配整个字符串aabab。这被称为贪婪匹配。
有时,我们更需要懒惰匹配,也就是匹配尽可能少的字符。前面给出的限定符都可以被转化为懒惰匹配模式,只要在它后面加上一个问号?。这样.?就意味着匹配任意数量的重复,但是在能使整个匹配成功的前提下使用最少的重复。现在看看懒惰版的例子吧:
a.*?b匹配最短的,以a开始,以b结束的字符串。如果把它应用于aabab的话,它会匹配aab(第一到第三个字符)和ab(第四到第五个字符)。
var str = 'hello "hunger" , hello "world"';
var pat = /".*?"/g;
str.match(pat); // 加一个问号? 转化成懒惰模式,尽量匹配少的字符