- \d,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^,$分别是什么?
\d:匹配数字
\w : 匹配数字、字符、字母、下划线
\s : 匹配空白符
[a-zA-Z0-9] : 匹配a到z,A到Z,0到9的字符
\b : 单词分隔符
. : 匹配除了\n\r之外的所有不字符
- : 重复0次或无限次
- : 重复一次或无限次,至少重复一个
?: 重复0次或1次,至少重复一次
X{3} : 字符x重复3次
^: 以什么开头
$: 以什么结尾
- 写一个函数trim(str),去除字符串两边的空白字符
function trim(str){
return str.replace(/^\s+|\s+$/g,'')
}
- 写一个函数isEmail(str),判断用户输入的是不是邮箱
function isEmail(str){
return /^\w@\w+.\w+$/.test(str)
}
console.log( isEmail('4@d.d'));
- 写一个函数isPhoneNum(str),判断用户输入的是不是手机号
function isPhoneNum(str){
return /^(86)?1[358]\d{9}$/.test(str)
}
console.log( isPhoneNum('13312222111'));
- 写一个函数isValidUsername(str),判断用户输入的是不是合法的用户名(长度6-20个字符,只能包括字母、数字、下划线)
function isValidUsername(str){
return /^\w{6,20}$/.test(str)
}
console.log( isValidUsername('1331_222111'));
- 写一个函数isValidPassword(str), 判断用户输入的是不是合法密码(长度6-20个字符,只包括大写字母、小写字母、数字、下划线,且至少至少包括两种)
function isValidPassword(str){
var count=0;
if(/^\w{6,20}$/.test(str)){
if(/[a-z]/.test(str)) count++;
if(/[A-Z]/.test(str)) count++;
if(/[0-9]/.test(str)) count++;
if(/_/.test(str)) count++;
if (count>=2) {return true ;} else{ return false;}
}else {return false;}
}
console.log( isValidPassword('133AA1_fgsr22ff111'));
- 写一个正则表达式,得到如下字符串里所有的颜色
var re =/[#][0-9a-fA-F]{6}/g /正则.../
var subj = "color: #121212; background-color: #AA00ef; width: 12px; bad-colors: f#fddee "
console.log( subj.match(re) ) // ['#121212', '#AA00ef']
- 下面代码输出什么? 为什么? 改写代码,让其输出[""hunger"", ""world""].
var str = 'hello "hunger" , hello "world"';
var pat = /"."/g;
str.match(pat);
输出: "hunger" , hello "world"
因为regular expression表达式中先匹配”,然后.可以匹配重复无限次的非\r\n的字符,最后在匹配“ 这个是贪婪模式
改写:var str = 'hello "hunger" , hello "world"';
var pat = /"\w"/g;或/".?"/g,改成非贪婪模式,加个?
console.log(str.match(pat));