1: \d,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^,$分别是什么?
\d:数字字符
\w:单词字符,字母、数字下划线
\s:空白符
[a-zA-Z0-9]:代表一个字符范围在a到z,A到Z,0到9
\b:单词边界
.:除了回车符和换行符之外的所有字符
*:出现任意次数
+:出现一次或者多次(至少出现 一次)
?:出现零次或一次(最多出现 一次)
x{3}:x出现3次
^:在中括号里叫取反,没有中括号在"//"里叫以xxx开头
$:以xxx结尾
2: 写一个函数trim(str),去除字符串两边的空白字符
function trim(str){
return str.replace(/^\s+|\s+$/g,'')
}
3: 写一个函数isEmail(str),判断用户输入的是不是邮箱
function isEmail(str){
var reg = /^\w+@\w+\.[a-zA-Z]+$/
return reg.test(str)
}
4: 写一个函数isPhoneNum(str),判断用户输入的是不是手机号
function isPhoneNum(str){
return /^1\d{10}$/.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{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(/^_{6,20}$/.test(str)) return false;
if(/^\d{6,20}$/.test(str)) return false;
else return true;
}
isValidPassword('_123ABDa')
//true
7: 写一个正则表达式,得到如下字符串里所有的颜色
var subj = "color: #121212; background-color: #AA00ef; width: 12px; bad-colors: f#fddee "
var reg = /#[0-9a-fA-F]{6}(?=;)|#[0-9a-fA-F]{3}(?=;)/g
//或者var reg = /#([0-9a-fA-F]{6}|[0-9a-fA-F]{3})(?=;)/g
console.log( subj.match(reg) ) // ['#121212', '#AA00ef']
8: 下面代码输出什么? 为什么? 改写代码,让其输出[""hunger"", ""world""].
var str = 'hello "hunger" , hello "world"';
var pat = /".*"/g;
str.match(pat);
//[""hunger" , hello "world""],浏览器默认是贪婪模式,把hello"也算入
var str = 'hello "hunger" , hello "world"';
var pat = /".*?"/g;
str.match(pat);
//[""hunger"", ""world""],改为非贪婪模式