regExp

\d,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^,$分别是什么?

\d 数字字符

\w 单词字符,字母、数字下划线

\s 空白符

[a-zA-Z0-9] 单词字符,字母、数字下划线

\b 单词边界

. 除了回车符和换行符之外的所有字符

* 出现零次或多次(任意次)

+ 出现一次或多次(至少出现一次)

? 出现零次或一次(最多出现一次)

x{3} 出现3次

^ 以xxx开头

$ 以xxx结尾

写一个函数trim(str),去除字符串两边的空白字符

function trim(str){
    var regExp = /^\s*|\s*$/g    
    // ^以...开头 \s空白字符 *出现任意次 |并且  $以...结尾 /g全局作用域
    return str.replace(regExp,'');
}
trim('     hello world    ')  //hello world

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

function isEmail(str) {
    var regExp = /[0-9a-z_A-Z]*@[0-9a-z_A-Z]{2,5}(.com)$/
    var flag= regExp.test(str)
    return flag
}
console.log(isEmail('[email protected]'))
console.log(isEmail('15846304414.com'))

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

function isPhoneNum(str) {
    var regExp = /^1[0-9]{10}/
    var flag= regExp.test(str)
    return flag
}

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

function isValidUsername(str){
    var regExp = /\w{6,20}/g
    return regExp.test(str)
}
console.log(isValidUsername('a15846_304414'))
console.log(isValidUsername('54545,54564'))
console.log(isValidUsername('sd<>d'))

写一个函数isValidPassword(str), 判断用户输入的是不是合法密码(长度6-20个字符,只包括大写字母、小写字母、数字、下划线,且至少至少包括两种)

function isValidPassword(str){
    var regExp = /(^\d{6,20}$)|(^[A-Z]{6,20}$)|(^(a-z){6,20}$)|^_{6,20}$|\W/
    return !regExp.test(str)
}

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

var re = /#[0-9a-zA-Z]{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""]
  • 因为默认是贪婪模式,会尽可能多匹配,所以我们要把它改成非贪婪模式,加一个?
var str = 'hello  "hunger" , hello "world"'
console.log(str)
var pat =  /".*?"/g
console.log(str.match(pat))

你可能感兴趣的:(regExp)