美文网首页
正则表达式

正则表达式

作者: 字母31 | 来源:发表于2017-10-25 20:38 被阅读0次

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

    \d:数字0-9
    \w:单词字符,字母、数字下划线
    \s:空白符
    [a-zA-Z0-9]:小写字母a-z 大写字母A-Z 数字0-9
    \b:字符边界
    .:除换行和空白字符以外的字符
    *:量词,表示0到多个
    +:量词,表示1到多个
    ?:量词,表示零次或1次
    x{3}:表示x匹配3次
    ^:表示开头的意思,在[]中表示非
    $:表示结尾

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

    function trim(str){
        return str.replace(/^\s+|\s+$/g, '')  //\s+$而不是\s$是避免字符串后面有多个空白符
    }
    

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

    function isEmail(str){
         var reg = /^\w+@\w+[.]\w+$/g
         return   reg.test(str)
    }
    

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

    function isPhoneNum(str){
         var reg = /^1[3|5|7|8]\d{9}$/g
         return   reg.test(str)
    }
    

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

    function isValidUsername(str){
         var reg = /^\w{6,20}$/g
         return   reg.test(str)
    }
    

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

    function isValidPassword(str){
         if(!/\w{6,20}$/g.test(str))  return false
         if(/^[0-9]{6,20}$/g.test(str))  return false
         if(/^[a-z]{6,20}$/g.test(str))  return false
         if(/^[A-Z]{6,20}$/g.test(str))  return false
         if(/^_{6,20}$/g.test(str))  return false
         return true
    }
    

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

    var re = /#([0-9a-fA-F]{6})|[0-9a-fA-F]{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 str = 'hello  "hunger" , hello "world"';
    var pat =  /".*?"/g;
    str.match(pat);
    非贪婪模式所以输出["hunger" ,"world"]
    

    相关文章

      网友评论

          本文标题:正则表达式

          本文链接:https://www.haomeiwen.com/subject/zqlcpxtx.html