第一個(gè)例子:/(\d0)+/.exec("10000000");分開(kāi)來(lái)看,首先,\d0的意思是,匹配1個(gè)數(shù)字和0,然后(\d0)用括號(hào)括起來(lái)表示這是一個(gè)分組,+表示這個(gè)分組至少要給老子匹配1次!不然就別說(shuō)你匹配了!o( ̄▽ ̄)o(如果少于1次,即0次算作是匹配失敗的,但是如果是*,即使是0次也算作匹配成功了,因?yàn)?代表的數(shù)量雖然也是越多越好,但是可以為0)好,對(duì)應(yīng)10000000來(lái)講,1開(kāi)始,10滿足\d0?是的!繼續(xù),發(fā)現(xiàn)后面剩下的都可以滿足,即整個(gè)字符串可以分成(10)(00)(00)(00)四個(gè)段來(lái)看,每段都滿足1個(gè)數(shù)字加0的情況,所以整個(gè)字符串就匹配啦,輸出~/(\d0)+/雖然意思是表示很多個(gè)分組,但是字面上只有一個(gè)分組,就是(\d0),這個(gè)分組具體代表的內(nèi)容隨著匹配向前走而改變,最后代表的是(10)(00)(00)(00)四個(gè)分段中的最后一個(gè),即00,輸出~第二個(gè)例子:/(\d0)/.exec("10000000");原理一樣,還是從1開(kāi)始,10滿足\d0,OK,匹配停止,雖然可以把10000000分成(10)(00)(00)(00)四個(gè)分段,雖然每個(gè)分段都匹配,不過(guò)這次/(\d0)/只能匹配一個(gè)分段了(正則表達(dá)式分組后面沒(méi)有數(shù)量詞如+*{n,m}等),所以,整個(gè)正則表達(dá)式匹配的結(jié)果就是10,然后(\d0)是這個(gè)這則表達(dá)式的第一個(gè)分組,同時(shí)也是唯一一個(gè)分組,輸出~所以就是10了。具體到題主的疑惑,我想是對(duì)于“輸出最后一個(gè)符合的”的理解了。實(shí)際上,如果匹配,exec輸出一個(gè)數(shù)組,數(shù)組第一個(gè)元素是匹配到的整個(gè)字符串,然后,如果正則表達(dá)式里面有分組,就輸出分組匹配到的內(nèi)容,這里不能分開(kāi)說(shuō),不能把這個(gè)分組單獨(dú)抽出來(lái)去匹配原始字符串,而是針對(duì)匹配到的結(jié)果那里來(lái)講的,個(gè)人理解成,輸出它對(duì)這次成功匹配的功勞。再舉個(gè)例子/(\d0)+/.exec("6100020506730");字符串從6開(kāi)始,61?不行,繼續(xù)往后走,10?可以了。10后面的00?滿足(\d0)!00后面的20?滿足(\d0)!20后面的50?滿足(\d0)!50后面的67?這次不行了,匹配到此為止!不管后面有什么,即使末尾有一個(gè)30也不管了,都不管了!所以,最后的匹配到了10002050這一段,分一下組(10)(00)(20)(50),最后一個(gè)分組是50;所以/(\d0)+/.exec("6100020506730");的結(jié)果就是["10002050","50"]