1.\d,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^,$分别是什么?
- \d匹配一个数字,等价于[0-9]
- \w匹配一个单字字符(字母、数字或者下划线),等价于[a-zA-Z0-9_]
- \s
匹配一个空白字符,包括空格、制表符、换页符和换行符。等价于[\t\n\x0B\f\r]
- [a-zA-Z0-9]匹配字母或数字
- \b:匹配一个词的边界。一个词的边界就是一个词不被另外一个词跟随的位置或者不是另一个词汇字符前边的位置。
- . (小数点)匹配除回车符和换行符之外的任何单个字符。
- *匹配前一个表达式0次或多次。等价于 {0,}。
- +匹配前面一个表达式1次或者多次。等价于 {1,}。
- ?匹配前面一个表达式0次或者1次。等价于 {0,1}。
- x{3}匹配连续出现的3个x。
- ^匹配输入的开始。如果多行标志被设置为true,那么也匹配换行符后紧跟的位置。如果^出现在[]里那么代表一个反向字符集。
- $匹配输入的结束。如果多行标示被设置为true,那么也匹配换行符前的位置。
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) {
var reg = /^1\d{10}$/
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{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(/^[0-9]{6,20}$/.test(str)) return false
if(/^_{6,20}$/.test()) return false
return true
}
7.写一个正则表达式,得到如下字符串里所有的颜色
var reg = /#([a-zA-Z0-9]{6}|[a-zA-Z0-9]{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 reg = /"\w+?"/g
str.match(reg) // [""hunger"", ""world""]