美文网首页
JS(五)正则表达式

JS(五)正则表达式

作者: Gia_Mo | 来源:发表于2017-03-26 12:20 被阅读0次
    1、 \d,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^,$分别是什么?
    • \d 表示匹配0-9之间的任一数字,相当于[0-9]
    • \w 表示匹配任意的字母、数字和下划线,相当于[0-9a-zA-Z]
    • \s 表示匹配任意的空格(包括制表符、空格符、换行符等)
    • [a-zA-Z0-9] 表示匹配任意的字母、数字、下划线,相当于\w
    • \b 表示匹配单词边界
    • . 表示匹配任意字符,除回车\r、换行符\n以外
    • * 表示匹配的字符出现0次或多次
    • + 表示匹配的字符出现1次或多次
    • 表示匹配的字符出现0次或一次
    • x{3} 表示x出现3次
    • ^ 表示以什么开头,在[]中表示取反
    • 表示以什么结尾
    2、写一个函数trim(str),去除字符串两边的空白字符
    function trim(str) {
        var exp = /^\s+|\s+$/g;
        return str.replace(exp,'');
    }
    console.log(trim('   jirengu  '))  // jirengu
    
    3、写一个函数isEmail(str),判断用户输入的是不是邮箱
    function isEmail(str) {
        var exp = /^\w+@[0-9a-z]+\.[a-z]+$/;
        return exp.test(str);
    }
    console.log(isEmail('jirengu@163.com')); // true
    console.log(isEmail('@163.com')); // false
    console.log(isEmail('jirengu@163com')); // false
    console.log(isEmail('jirengu@.com')); // false
    
    4: 写一个函数isPhoneNum(str),判断用户输入的是不是手机号
    function isPhoneNum(str) {
        var exp = /^1[3|5|6|7|8][0-9]{9}$/;
        return exp.test(str);
    }
    console.log(isPhoneNum('13888888888')) // true
    console.log(isPhoneNum('1388888888'))  // false
    console.log(isPhoneNum('14888888888')) // false
    
    5: 写一个函数isValidUsername(str),判断用户输入的是不是合法的用户名(长度6-20个字符,只能包括字母、数字、下划线)
    function isValidUsername(str) {
        var exp = /^\w{6,20}$/;
        return exp.test(str);
    }
    console.log(isValidUsername('jirengu001')); // true
    console.log(isValidUsername('ji001'));  // false
    console.log(isValidUsername('jirengu001001001001001')); //false
    console.log(isValidUsername('jirengu001*hah')); //false
    
    6: 写一个函数isValidPassword(str), 判断用户输入的是不是合法密码(长度6-20个字符,只包括大写字母、小写字母、数字、下划线,且至少至少包括两种)
    function isValidPassword(str) {
        var exp = /^\w{6,20}$/;
        var exp1 = /^[0-9]{6,20}$/;
        var exp2 = /^[a-z]{6,20}$/;
        var exp3 = /^[A-Z]{6,20}$/;
        var exp4 = /^[_]{6,20}$/;   
        if (exp.test(str)) {
            if (exp1.test(str) || exp2.test(str) || exp3.test(str) || exp4.test(str)) {
                return false
            } else {
                return true
            }
        } else {
            return false;
        }
    }
    console.log(isValidPassword('jirengu001')) // true
    console.log(isValidPassword('jirengu')) // false
    console.log(isValidPassword('000000')) // false
    console.log(isValidPassword('______')) // false
    console.log(isValidPassword('JIRENGU')) // false
    console.log(isValidPassword('jiren')) // false
    
    7、 写一个正则表达式,得到如下字符串里所有的颜色
    var re = /#\w{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;
    console.log(str.match(pat)); // [""hunger" , hello "world""] 因为默认是贪婪模式,所以会一直匹配到最后一个双引号
    //改写后
    var pat = /".*?"/g;
    console.log(str.match(pat)); // [""hunger"", ""world""]
    

    相关文章

      网友评论

          本文标题:JS(五)正则表达式

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