0.学习正则表达式
1. \d,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^,$分别是什么?
- \d 代表一个0-9的数字字符
- \w 代表[0-9A-Za-z_]中的一个字符
- \s 代表一个空白字符,空白字符可以是\t水平制表符,\n换行符,\f换页符,\r回车符。
- [a-zA-Z0-9]代表由a-z,A-Z,0-9范围内的任一字符。
- \b代表单词边界。
- ·代表除了\r,\n外的任一字符。
- *代表出现次数为0次或者多次,即任意次。
- +代表出现一次或者多次。
- ?代表出现0次或者一次。
- x{3}代表x出现的次数是3
- 以xxx开头。同时[]则代表取反。
- $代表以xxx结尾。
2.写一个函数trim(str),去除字符串两边的空白字符
function trim(str){
var str1
str1=str.replace(/^\s+|\s+$/g)
return str1
}
3.写一个函数isEmail(str),判断用户输入的是不是邮箱
function isEmail(str){
var reg=/\w+@\w+.\w+$/g
console.log(reg.test(str))
}
var str='234q34@qq.com*'
console.log(isEmail(str))
4.写一个函数isPhoneNum(str),判断用户输入的是不是手机号'
function isPhoneNum(str){
var reg=/1[3,5,7,8]\d{9}/
console.log(reg.test(str))
}
var str=135300000000000
console.log(isPhoneNum(str))
5. 写一个函数isValidUsername(str),判断用户输入的是不是合法的用户名(长度6-20个字符,只能包括字母、数字、下划线)
function isValidUsername(str){
var reg=/\w{6,20}/
console.log(reg.test(str))
}
var username='nihaoyadadf'
console.log(isValidUsername(username))
6.写一个函数isValidPassword(str), 判断用户输入的是不是合法密码(长度6-20个字符,只包括大写字母、小写字母、数字、下划线,且至少至少包括两种)
function isValidPassword(str){
var reg=/^\w{6,20}$/
console.log(reg.test(str))
if(reg.test(str)&&!/_+$/.test(str)&&!/\d+$/.test(str)&&!/^[a-zA-Z]+$/.test(str)){
console.log('true')
}else{
console.log('false')
}
}
var str='nihaoa_'
console.log(isValidPassword(str))
7. 写一个正则表达式,得到如下字符串里所有的颜色
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']
8.下面代码输出什么? 为什么? 改写代码,让其输出[""hunger"", ""world""].
var str = 'hello "hunger",hello "world"';
var pat = /".*"/g;
str.match(pat);//["hunger"++hello "world"],因为贪婪模式下,匹配到"hunger"后继续尝试,发现,hello"world"仍然符合reg规则,就全部列入,这时候g实际上并没有发挥作用,因为后面全符合reg规则
修改代码
var pat=/".*?"/g //就可以了,因为在非贪婪模式下,匹配到''hunger"以后,就停止了,然后再调用全局的match,接着"hunger"继续匹配。g发挥作用了。