进阶7

作者: upup_dayday | 来源:发表于2017-10-01 08:07 被阅读0次

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

    \d——等价[0-9],数字字符类
    \w——等价[a-zA-Z_0-9],单词字符,字母、数字下划线
    \s——等价[\t\n\x0B\f\r],空白符
    [a-zA-Z0-9]——创建了一个类,代表一个字符,该字符可以是a-zA-Z0-9中任意一个
    \b——单词边界
    .——除了回车符和换行符之外的所有字符,[^\r\n]
    *——出现零次或多次(任意次)
    +——出现一次或多次(至少出现一次)
    ?——出现零次或一次(最多出现一次)
    x{3}——x出现3次
    ——结合[],可做取反使用[abc]不包含abc,也用作筛选字符串开头,/^hello/,以hello开头
    $——/hello&/,以hello结尾

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

    去除字符串开头和结尾的空白字符
    function trim(str){
      var strBegin = /^\s+/;
      var strEnd = /\s+$/;
      var tempStr = str.replace(strBegin, '');
      tempStr = tempStr.replace(strEnd, '');
    
      return tempStr;
    }
    
    去除字符串中所有空白字符
    function trim(str){
      var reg = /\S+/g;
      var result = '';
      while(r=reg.exec(str)){
        result += r[0];
      }
    
      return result;
    }
    

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

    function isEmail(str){
      var reg = /(^[a-zA-Z0-9])+[\w\.]+\w+@[a-zA-Z0-9]+\.\w+[a-zA-Z]$/;
      return reg.test(str)
    }
    

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

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

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

    function isValidUsername(str){
      var reg = /^\w\w{5,9}$/;
      return reg.test(str);
    }
    

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

    function isValidPassword(str){
      var rule1 = /^\w\w{5,19}$/;
      var rule2 = /\d+/;
      var rule3 = /[a-z]+/;
      var rule4 = /[A-Z]+/;
      var rule5 = /_+/;
      var resultSum = rule2.test(str) + rule3.test(str) + rule4.test(str) + rule5.test(str);
    
      return (rule1.test(str) && (resultSum >= 2));
    }
    

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

    var re = /#[a-zA-Z0-9]{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);
    

    因为贪婪模式,尽可能多的匹配,加上?,尽可能少的匹配

    var str = 'hello  "hunger" , hello "world"';
    var pat =  /".*?"/g;
    str.match(pat);
    

    相关文章

      网友评论

          本文标题:进阶7

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