美文网首页
正则表达式

正则表达式

作者: cctosuper | 来源:发表于2017-11-06 16:11 被阅读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] 所有大小写字母及数字
    \b 单词边界
    . 除回车和换行外的所有字符[^\r\n]
    * 出现零次或多次
    + 出现一次或多次
    ? 出现零次或一次
    x{3} x出现三次
    ^ 以xxx开头(若在[]内则是取反的意思)
    $ 以xxx结尾

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

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

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

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

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

    function isPhoneNum(str){
      var reg = /^1\d{10}/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}$/.test(str)) return false
      if(/^\d{6,20}$/.test(str)) return false
      if(/^[A-Z]{6,20}$/.test(str)) return false
      if(/^[a-z]{6,20}$/.test(str)) return false
      if(/^_{6,20}$/.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""]
    
    解析:匹配`"`前任意多个除回车加换行符之外的所有字符的字符串,因为处于贪婪模式下,所以得到的就是上面的结果;
    想要得到[""hunger"", ""world""]的结果可以将正则改为如下代码:
    var pat =  /".*?"/g;//非贪婪模式
    

    相关文章

      网友评论

          本文标题:正则表达式

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