正则

作者: 我竟无言以对_1202 | 来源:发表于2017-12-19 19:31 被阅读0次

    正则的方法
    test:正则去匹配字符串,如果匹配成功为true,失败返回false

    var str = 'abcdefg';
    var re = /b/;
    alert(re.test(str)); 
    

    转义字符:
    \s :空格
    \S :非空格
    \d :数字
    \D :非数字
    \w :字符 (字母、数字、下划线)
    \W :非数字
    . :任意字符
    \b :独立的部分 (起始、结束、空格)
    \B :非独立的部分
    \1 :重复的第一个子项
    \2 :重复的第二个子项

    var str = '3124354657665';
    var re = /\D/;
    if(re.test(str)){
        alert('不全是数字');
    }else{
        alert('全是数字');
    }
    
    var str = 'onetwo';
    var re1 = /\bone/;
    var re2 = /one\b/;
    alert(re1.test(str)); //返回true
    alert(re2.test(str)); //返回false
    

    search:正则去匹配字符串,如果匹配成功就返回匹配成功的位置,失败返回-1

    var str = 'abcdefg';
    var re = /b/;
    alert(str.test(re)); 
    
    var str = 'abca';
    var re1 = /(a)(b)(c)\1/;
    var re2 = /(a)(b)(c)\2/;
    alert(re1.test(str));  //返回true
    alert(re2.test(str));  //返回false
    

    正则默认区分大小写,如果不区分大小写,在正则的最后加标识

    var str = 'abcdefg';
    // var re = /b/i;
    var re = new RegExp('b','i');
    alert(str.test(re)); 
    

    match:正则去匹配字符串,如果成功,返回匹配成功的数组,如果不成功,返回null

    正则默认匹配成功就会结束,不会继续匹配,如果想全部查找,就要加标识g(全局匹配)
    量词:匹配不确定的位置{}
    {4,7} :最少出现4次,最多出现7次
    {4,} :最少出现4次
    {4} :正好出现4次
    + :至少出现一次 {1,}
    ? :0次或1次 {0,1}
    * :至少出现0次 {0,}
    ^ :正则起始的位置
    $ :正则结束的位置
    例:QQ号匹配:re = /^[1-9]\d{4,11}$/;

    var str = 'hasd213dsafet54sadsa656dasdsa789';
    var re = /\d+/g;
    alert(str.match(re));
    

    replace:正则去匹配字符串,匹配成功的字符去替换成新的字符串,第二个参数可以是字符串,也可以是一个回掉函数

    var str = 'aaa';
    var re = /a/g;
    str = str.replace(re,'b');
    alert(str);
    

    例子:敏感词过滤

    <!doctype html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
    </head>
    <body>
        <textarea name="" id="" cols="30" rows="10"></textarea>
        <textarea name="" id="" cols="30" rows="10"></textarea>
        <input type="button" value="确定" id="input1">
    </body>
    <script>
    /*很奇怪,大家对于前任总是有一种特殊的情感。 最不想提起的是前任,但是怎么也不能彻底忘记的也是前任。*/
    window.onload = function(){
        var aT = document.getElementsByTagName('textarea');
        var oInput = document.getElementById('input1');
    
        var re = /前任|情感|彻底忘记/g;
    
        oInput.onclick = function(){
            //aT[1].value = aT[0].value.replace(re,'*');
            aT[1].value = aT[0].value.replace(re,function(str){
                //函数的第一个参数,就是匹配成功的字符
                
                var result = '';
                for(var i=0;i<str.length;i++){
                    result += '*';
                }
                return result;
            })
        }
    }
    </script>
    </html>
    

    匹配子项:小括号() (还有另一种意思,分组操作)

    var str = '2016-6-7';
    var re = /(\d+)(-)/g;
    str.replace(re,function($0,$1,$2){
        //第一个参数:母亲,即正则整体,第二个参数:第一个孩子,即第一个小括号的正则,以此类推
        
        return $1 + '.'; //输出2016.6.7
    })
    

    正则表达式中的字符类
    字符类:一组相似的元素,[]中括号整体代表一个字符

    var str = 'abc';
    var re = /a[bde]c/;
    alert(re.test(str)); //返回true
    

    排除:如果写在[]里面的话,就代表排除的意思

    var str = 'abc';
    var re = /a[^bde]c/;
    alert(re.test(str)); //返回false
    

    范围:[a-z][0-9][A-Z]

    去掉前后空格

    var str = ' hello ';
    
    function trim(str){
        var re = /^\s+|\s+$/g;
        return str.replace(re,'');
    }
    alert(trim(str));
    

    匹配中文:[\u4e00-\u9fa5]
    行首行尾空格:^\s|\s$
    email:^\w+@[a-z0-9]+(.[a-z]+){1,3}$
    网址:[a-zA-z]+://[^\s]*
    QQ:[1-9][0-9]{4-9}
    邮政编码:[1-9]\d{5}
    身份证:[1-9]\d{14}|[1-9]\d{17}|[1-9]\d{16}x

    相关文章

      网友评论

          本文标题:正则

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