內(nèi)容全寫(xiě)注釋里了- -
復(fù)制代碼 代碼如下:
script type="text/javascript">
/^$/.test('\n'); //false,為什么呢,說(shuō)明如下
var p = /^/mg;
var s = '1\n\n\n2\n\n3';
p.test(s); //跳過(guò)開(kāi)始位置JS里好象沒(méi)那個(gè)詞- -
p.test(s);
alert(RegExp.rightContext.replace(/\x0A/g, '\\a'));
//由此得出^匹配的是\n后面的位置或開(kāi)始的位置
var p = /$/mg;
var s = '1\n\n\n2\n\n3';
p.test(s);
alert(RegExp.rightContext.replace(/\x0A/g, '\\a'));
//由此得出$匹配的是\n前面的位置或結(jié)尾的位置
var p = /^\s*$/mg;
var s = '1\n\n\n2\n\n3';
alert(s.replace(p, function (l, index) {
alert(index);
return '';
}).replace(/\x0A/g, '\\a'));
/*
即位置或范圍用|表示
第一次匹配
注錨點(diǎn)不耗字符,所以它匹配的內(nèi)容是位置用|標(biāo)明
內(nèi)容用|內(nèi)容|標(biāo)明
^匹配的位置是1\n|\n\n2\n3\n4\n5
\s匹配的是內(nèi)容是1\n|\n|\n2\n3\n4\n5
$匹配的位置是1\n\n|\n2\n3\n4\n5
這時(shí)lastIndex為1\n\n|\n2\n3\n4\n5
所以第二次匹配時(shí)
^匹配的位置是1\n\n|\n2\n3\n4\n5
\s匹配了\n,然后$沒(méi)成功所以回溯一次,然后匹配成功所以它實(shí)際沒(méi)匹配東西即內(nèi)容是1\n\n||\n2\n3
\n4\n5(就是空的)
$匹配的位置是1\n\n|\n2\n3\n4\n5
然后發(fā)現(xiàn)沒(méi)變位置,所以強(qiáng)制驅(qū)動(dòng),設(shè)置lastIndex為1\n\n\n|2\n3\n4\n5
后面的操作和這次一樣。。。所以匹配執(zhí)行了3次
分開(kāi)來(lái)看執(zhí)行下面代碼。。。
*/
var p = /^\s*$/mg;
var s = '1\n\n\n2\n\n3';
p.test(s); //true
alert(RegExp.lastIndex); //3
p.test(s); //true
alert(RegExp.lastIndex); //強(qiáng)制驅(qū)動(dòng)后的結(jié)果即4
p.test(s); //true
alert(RegExp.lastIndex); //7
p.test(s); //false
alert(RegExp.lastIndex); //匹配失敗沒(méi)設(shè)置global的RegExp對(duì)象
/^X$/g.test('a'); //false
alert(RegExp.lastIndex); //注:匹配失敗是不會(huì)設(shè)置global的RegExp對(duì)象的
/^X$/.test('X'); //true
alert(RegExp.lastIndex); //匹配成功當(dāng)然會(huì)設(shè)置^^
/script>
您可能感興趣的文章:- JavaScript學(xué)習(xí)小結(jié)(7)之JS RegExp
- javascript正則表達(dá)式和字符串RegExp and String(二)
- javascript正則表達(dá)式和字符串RegExp and String(一)
- JavaScript通過(guò)RegExp實(shí)現(xiàn)客戶端驗(yàn)證處理程序
- javascript 中String.match()與RegExp.exec()的區(qū)別說(shuō)明
- JS正則中的RegExp對(duì)象對(duì)象
- js正則表達(dá)式講解之index屬性(RegExp對(duì)象)
- javascript 正則替換 replace(regExp, function)用法
- JavaScript 核心參考教程 RegExp對(duì)象
- javascript RegExp對(duì)象(正則表達(dá)式)
- JS正則表達(dá)式字面量和使用new RegExp構(gòu)造函數(shù)創(chuàng)建的正則表達(dá)式有什么區(qū)別
- 詳解JavaScript RegExp對(duì)象