javascript RegExp multiline多行匹配影响的^$
<script type="text/javascript">
/^$/.test('n'); //false,为什么呢,说明如下
var p = /^/mg;
var s = '1nnn2nn3';
p.test(s); //跳过开始位置JS里好象没那个词- -
p.test(s);
alert(RegExp.rightContext.replace(/x0A/g, '\a'));
//由此得出^匹配的是n后面的位置或开始的位置
var p = /$/mg;
var s = '1nnn2nn3';
p.test(s);
alert(RegExp.rightContext.replace(/x0A/g, '\a'));
//由此得出$匹配的是n前面的位置或结尾的位置
var p = /^s*$/mg;
var s = '1nnn2nn3';
alert(s.replace(p, function (l, index) {
alert(index);
return '';
}).replace(/x0A/g, '\a'));
/*
即位置或范围用|表示
第一次匹配
注锚点不耗字符,所以它匹配的内容是位置用|标明
内容用|内容|标明
^匹配的位置是1n|nn2n3n4n5
s匹配的是内容是1n|n|n2n3n4n5
$匹配的位置是1nn|n2n3n4n5
这时lastIndex为1nn|n2n3n4n5
所以第二次匹配时
^匹配的位置是1nn|n2n3n4n5
s匹配了n,然后$没成功所以回溯一次,然后匹配成功所以它实际没匹配东西即内容是1nn||n2n3
n4n5(就是空的)
$匹配的位置是1nn|n2n3n4n5
然后发现没变位置,所以强制驱动,设置lastIndex为1nnn|2n3n4n5
后面的操作和这次一样。。。所以匹配执行了3次
分开来看执行下面代码。。。
*/
var p = /^s*$/mg;
var s = '1nnn2nn3';
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>
浅谈正则表达式 实例入门
很长时间没看正则表达式了,碰巧今天用到,温故知新了一把看书学习吧50%的举一反三练习中的原创。一javascript正则表达式的基本知识1javascript正则对
关于IE的RegExp.exec的问题
代码如下:varst="A[B]C[D]E[F]G";varreg=/[w]/ig;vars1=st.replace(reg,"");vars2=[];vararr;while((arr=reg.exec(st))!=null)s2.push(arr[0]);alert(s1);alert(s2.join(""));FF下正确显示,IE下S2为
asp.net 正则表达式的应用
1.平衡组/递归匹配(?'group')将名为group对应的内容,压栈计数;(?'-group')将名为group的对应的内容,出栈计数(?!)零宽负向先行断言,由于没有后缀表达式,试
标签:位置,内容,的是,正则表达式,递归