Regular Expression

  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 : 单词分隔符
    . : 匹配除了\n\r之外的所有不字符
  • : 重复0次或无限次
  • : 重复一次或无限次,至少重复一个
    ?: 重复0次或1次,至少重复一次
    X{3} : 字符x重复3次
    ^: 以什么开头
    $: 以什么结尾
  1. 写一个函数trim(str),去除字符串两边的空白字符

function trim(str){
return str.replace(/^\s+|\s+$/g,'')
}

  1. 写一个函数isEmail(str),判断用户输入的是不是邮箱

function isEmail(str){
return /^\w@\w+.\w+$/.test(str)
}
console.log( isEmail('[email protected]'));

  1. 写一个函数isPhoneNum(str),判断用户输入的是不是手机号

function isPhoneNum(str){
return /^(86)?1[358]\d{9}$/.test(str)
}
console.log( isPhoneNum('13312222111'));

  1. 写一个函数isValidUsername(str),判断用户输入的是不是合法的用户名(长度6-20个字符,只能包括字母、数字、下划线)

function isValidUsername(str){
return /^\w{6,20}$/.test(str)
}
console.log( isValidUsername('1331_222111'));

  1. 写一个函数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'));

  1. 写一个正则表达式,得到如下字符串里所有的颜色

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']

  1. 下面代码输出什么? 为什么? 改写代码,让其输出[""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));

你可能感兴趣的:(Regular Expression)