美文网首页
进阶-任务7

进阶-任务7

作者: nicole914 | 来源:发表于2017-03-14 13:06 被阅读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:单词边界
    . : 除了回车符和换行符之外的所有字符
    *: 出现零次或多次(任意次)
    +: 出现一次或多次(至少出现一次)
    ? : 出现零次或一次(最多出现一次)
    x{3} : x出现3次
    ^ : 以xxx开头
    $ : 以xxx而结尾

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

    function trim(str) {
        return str.replace(/^\s+|\s+$/g, '')
    }
    var str = '  #id div.class  '
    console.log(trim(str))
    

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

    function isEmail(str)   
    {  
        return /^\w+([\.-]?\w+)*@\w+([\.-]?\w+)*(\.\w{2,3})+$/.test(str)
    }  
    var str1 = 'my.ownsite@ourearth.org'
    var str2 = 'mysite123@gmail.b'
    console.log(isEmail(str1))
    console.log(isEmail(str2))
    

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

    function isPhoneNum(str) {
        return /^(86)?1[34578]\d{9}$/.test(str)
    }
    var str1 = 15822938402;
    var str2 = 1028475920;
    console.log(isPhoneNum(str1))
    console.log(isPhoneNum(str2))
    

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

    function isValidUsername(str) {
        return /^\w{6,20}$/.test(str.trim())
    }
    

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

    function isValidPassword(str) {
        str = str.trim();
        if(/^\w{6,20}$/.test(str)) {
            if(/^\d+$/.test(str)) {
                return false
            }else if (/^[a-zA-Z]+$/.test(str)){
                return false
            }else if (/^_+$/.test(str)){
                return false
            }else {
                return true
            }
        }else {
            return false;
        }
    }
    

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

    var re = /#([a-fA-F0-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""].

    因为默认会进行贪婪匹配,所以会输出[ '"hunger" , hello "world"' ]

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

    相关文章

      网友评论

          本文标题:进阶-任务7

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