成人无码视频,亚洲精品久久久久av无码,午夜精品久久久久久毛片,亚洲 中文字幕 日韩 无码

資訊專欄INFORMATION COLUMN

JavaScript正則需要注意的地方

wums / 1554人閱讀

摘要:和區(qū)別當(dāng)采用非全局匹配的時(shí)候,兩個(gè)方法的返回值完全一樣。和都只匹配一次,且都會(huì)把分組抽出來(lái)放到數(shù)組后面當(dāng)為全局匹配的時(shí)候,方法返回一個(gè)存放所有匹配內(nèi)容的數(shù)組無(wú)視子表達(dá)式的匹配。

exec()和match()區(qū)別

當(dāng)采用非全局匹配的時(shí)候,兩個(gè)方法的返回值完全一樣。

match和exec都只匹配一次,且都會(huì)把分組抽出來(lái)放到數(shù)組后面

    (function(){
        
        let str="antzoane";
        let reg=/(a)(n)/;
        console.log(str.match(reg));
        console.log(reg.exec(str));
    })();
    

當(dāng)為全局匹配的時(shí)候,match方法返回一個(gè)存放所有匹配內(nèi)容的數(shù)組(無(wú)視子表達(dá)式的匹配)。

exex方法返回?cái)?shù)組不會(huì)存儲(chǔ)所有的匹配,僅存儲(chǔ)第一個(gè)匹配到的內(nèi)容(存儲(chǔ)在數(shù)字第一個(gè)元素),第二個(gè)元素存儲(chǔ)第一個(gè)子表達(dá)式匹配到的內(nèi)容,第三個(gè)元素存儲(chǔ)第二個(gè)子表達(dá)式匹配到的內(nèi)容,以此類推

    (function(){
       
        let str="antzoane";
        let reg=/a(n)/g;
        console.log(str.match(reg));
        console.log(reg.exec(str));
        //再次調(diào)用從上次的lastindex開(kāi)始匹配;
        console.log(reg.exec(str));
    })();

match()和分組匹配
    var reg = /(d{4})-(d{2})-(d{2})/;
    var dateStr = "2018-04-18";
    var s=dateStr.match(reg);
    console.log(s)//arr[0]是匹配的結(jié)果,arr[1]是第一個(gè)()里的匹配內(nèi)容,全局匹配不會(huì)返回()里的內(nèi)容

    var str="hello my name is ben   ,this is  ";
    var reg2=/ {1,}/g;
    var reg22=/( ){1,}/g//()內(nèi)看成一個(gè)整體去匹配
    console.log(str.match(reg2));
    console.log(str.match(reg22));

replace()和分組捕獲 全部匹配添加修飾
    var str="0816-2323263";
    var reg=/(d+)(-)(d+)/g;
    var str2=str.replace(reg,"($1)-$3");//全部匹配添加修飾
    console.log(str2);//(0816)-2323263
(?)與(?:exp)
var str1="123478basd-12aaaaa";
    var reg1=/(d+)([a-z]+)(d+)(?[a-z]+)/g;
    var str21=str1.replace(reg1,"$1hhhhh$");//(?)捕獲文本到名稱為name的組里  (?:exp)匹配exp,不捕獲匹配的文本,也不給此分組分配組號(hào)
    console.log(str21);//123478basd-12aaaaa
匹配需要?jiǎng)h除的部分然后置空
 var str23="123478basd12asdsa";
    var reg2=/[a-z]+/g;
    var str22=str23.replace(reg2,"");//匹配需要?jiǎng)h除的部分然后置空
    console.log(str22);//12347812
貪婪與懶惰

在量詞后面加個(gè)問(wèn)號(hào)表示懶惰,盡可能少的匹配

   
    var str="abc8defghij7klngon8qrstwxy7";
    var reg1=/8[a-zA-Z0-9]*7/;
    var reg2=/8[a-zA-Z0-9]*?7/;
    var reg3=/8[a-zA-Z0-9]+?/;
    var res1=str.match(reg1);
    var res2=str.match(reg2);
    var res3=str.match(reg3);
    console.log(res1);
    console.log(res2);
    console.log(res3);

零寬斷言

(?=exp)向前查找

(?<=exp)向后查找

(?!exp)匹配后面跟的不是exp的位置

(?

    (function(){
        var str="http://www.sina.com.cn ";
        var reg1= new RegExp(/.+(:)/g);
        var res1=str.match(reg1);
        var reg2=new RegExp(/.+(?=:)/);
        var res2=str.match(reg2);
        console.log(res1);
        console.log(res2);
    })();

    (function(){
        var a = "價(jià)格是123456789.6754";
        var reg4= new RegExp(/(d)(?=(d{3})+.)/g);
        console.log(a.match(reg4));
        var b = a.replace(reg4, "$1,");
        console.log(b)
    })();

    (function(){
        let str="ABCD01:$23.45";
        let reg1=/$[0-9.]+/g;
        let reg2=/(?<=$)[0-9.]+/g;
        let res1=str.match(reg1);
        let res2=str.match(reg2);
        console.log(res1);
        console.log(res2);
    })();

匹配固定位數(shù)

匹配固定位數(shù)時(shí),不能/[1-9]d{4,11}/這樣寫(xiě),這樣輸入15位也會(huì)從15位中成功匹配11位

只能用^和$匹配字符串開(kāi)始和結(jié)束位置,然后再匹配中間的位數(shù)(^$不是從哪里開(kāi)始匹配

    function check(val) {
        console.log(val)
        var reg = /^[1-9]d{4,8}[0-9]$/;//匹配5到10位qq號(hào)
        if (!reg.test(val)) {
            alert("輸入有誤");
        }else{
            alert("輸入正確");
        }
    }

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.hztianpu.com/yun/105209.html

相關(guān)文章

  • JavaScript正則需要注意地方

    摘要:和區(qū)別當(dāng)采用非全局匹配的時(shí)候,兩個(gè)方法的返回值完全一樣。和都只匹配一次,且都會(huì)把分組抽出來(lái)放到數(shù)組后面當(dāng)為全局匹配的時(shí)候,方法返回一個(gè)存放所有匹配內(nèi)容的數(shù)組無(wú)視子表達(dá)式的匹配。 exec()和match()區(qū)別 當(dāng)采用非全局匹配的時(shí)候,兩個(gè)方法的返回值完全一樣。 match和exec都只匹配一次,且都會(huì)把分組抽出來(lái)放到數(shù)組后面 (function(){ ...

    Rainie 評(píng)論0 收藏0
  • 一道小小題目引發(fā)對(duì)javascript支持正則表達(dá)式相關(guān)方法探討

    摘要:返回值返回值根據(jù)傳入的參數(shù)類型和規(guī)則的不同,返回的內(nèi)容不同,但總體來(lái)說(shuō),它是返回一個(gè)對(duì)象,而不是索引,如果沒(méi)匹配到任何符合條件的字符串,則返回。 本文發(fā)布在我的博客一道小小的題目引發(fā)對(duì)javascript支持正則表達(dá)式相關(guān)方法的探討許可協(xié)議: 署名-非商業(yè)性使用-禁止演繹 4.0 國(guó)際 轉(zhuǎn)載請(qǐng)保留原文鏈接及作者。 以前對(duì)于正則是非常懼怕的,因?yàn)榭床欢蛯W(xué)不會(huì)。但最近項(xiàng)目中頻繁的...

    Scholer 評(píng)論0 收藏0
  • 正則系列——JavaScript正則表達(dá)式基礎(chǔ)語(yǔ)法鞏固篇

    摘要:基礎(chǔ)語(yǔ)法鞏固正則表達(dá)式引擎根據(jù)正則去匹配字符的時(shí)候,是通過(guò)檢查索引的方式。妻原配就是好,可以直接使用正則表達(dá)式調(diào)用它。下面解釋一下上面這些常用的元字符查找單個(gè)字符,除了換行和行結(jié)束符。正則系列文章整理到了 上一章內(nèi)容:正則表達(dá)式實(shí)戰(zhàn)篇 知識(shí)回顧 前2章分別學(xué)習(xí)了正則表達(dá)式入門技巧,以及遇到正則需求該如何去分析問(wèn)題,還有正則表達(dá)式實(shí)戰(zhàn)的一些場(chǎng)景解釋。 這一章內(nèi)容偏向理論,推薦你點(diǎn)擊開(kāi)頭的...

    phodal 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

閱讀需要支付1元查看
<