內容全寫注釋里了- -
復制代碼代碼如下:
<script type="text/javascript">
/^$/.test('/n'); //false,為什么呢,說明如下
var p = /^/mg;
var s = '1/n/n/n2/n/n3';
p.test(s); //跳過開始位置JS里好象沒那個詞- -
p.test(s);
alert(RegExp.rightContext.replace(//x0A/g, '//a'));
//由此得出^匹配的是/n后面的位置或開始的位置
var p = /$/mg;
var s = '1/n/n/n2/n/n3';
p.test(s);
alert(RegExp.rightContext.replace(//x0A/g, '//a'));
//由此得出$匹配的是/n前面的位置或結尾的位置
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'));
/*
即位置或范圍用|表示
第一次匹配
注錨點不耗字符,所以它匹配的內容是位置用|標明
內容用|內容|標明
^匹配的位置是1/n|/n/n2/n3/n4/n5
/s匹配的是內容是1/n|/n|/n2/n3/n4/n5
$匹配的位置是1/n/n|/n2/n3/n4/n5
這時lastIndex為1/n/n|/n2/n3/n4/n5
所以第二次匹配時
^匹配的位置是1/n/n|/n2/n3/n4/n5
/s匹配了/n,然后$沒成功所以回溯一次,然后匹配成功所以它實際沒匹配東西即內容是1/n/n||/n2/n3
/n4/n5(就是空的)
$匹配的位置是1/n/n|/n2/n3/n4/n5
然后發現沒變位置,所以強制驅動,設置lastIndex為1/n/n/n|2/n3/n4/n5
后面的操作和這次一樣。。。所以匹配執行了3次
分開來看執行下面代碼。。。
*/
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); //強制驅動后的結果即4
p.test(s); //true
alert(RegExp.lastIndex); //7
p.test(s); //false
alert(RegExp.lastIndex); //匹配失敗沒設置global的RegExp對象
/^X$/g.test('a'); //false
alert(RegExp.lastIndex); //注:匹配失敗是不會設置global的RegExp對象的
/^X$/.test('X'); //true
alert(RegExp.lastIndex); //匹配成功當然會設置^^
</script>