javascript RegExp multiline多行匹配影响的^$
更新时间:2010年03月07日 23:45:38 作者:
javascript RegExp multiline多行匹配影响的^$,代码中有详细的注释,方法大家学习。
内容全写注释里了- -
<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>
复制代码 代码如下:
<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>
您可能感兴趣的文章:
- JavaScript学习小结(7)之JS RegExp
- javascript正则表达式和字符串RegExp and String(二)
- javascript正则表达式和字符串RegExp and String(一)
- JavaScript通过RegExp实现客户端验证处理程序
- javascript 中String.match()与RegExp.exec()的区别说明
- JS正则中的RegExp对象对象
- js正则表达式讲解之index属性(RegExp对象)
- javascript 正则替换 replace(regExp, function)用法
- JavaScript 核心参考教程 RegExp对象
- javascript RegExp对象(正则表达式)
- JS正则表达式字面量和使用new RegExp构造函数创建的正则表达式有什么区别
- 详解JavaScript RegExp对象
最新评论