正则表达式

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='[email protected]*'
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发挥作用了。

你可能感兴趣的:(正则表达式)