js/javascript正则表达式中/g /i /m的用法,以及实例(转)
2016-05-13 13:52
337 查看
正则的思想都是一样的,但是具体的写法会有所不同,在这里提到的/g,/i,/m在其他的地方也许就不能用了。
一,js正则标志/g,/i,/m说明
1,/g 表示该表达式将用来在输入字符串中查找所有可能的匹配,返回的结果可以是多个。如果不加/g最多只会匹配一个
2,/i 表示匹配的时候不区分大小写
3,/m 表示多行匹配,什么是多行匹配呢?就是匹配换行符两端的潜在匹配。影响正则中的^$符号
二,实例说明
1,/g的用法
<script type="text/javascript">
str = "tankZHang (231144)"+
"tank ying (155445)";
res = str.match(/tank/); //没有加/g
alert(res); //显示一个tank
res = str.match(/tank/g); //加了/g
alert(res); //显示为tank,tank
<STRONG></script></STRONG>
2,/i的用法
<script type="text/javascript">
str = "tankZHang (231144)"+ "tank ying (155445)";
res = str.match(/zhang/);
alert(res); //显示为null
res = str.match(/zhang/i); //加了/i
alert(res); //显示为ZHang
</script>
3,/m的用法
<script type="text/javascript">
var p = /$/mg;
var s = '1\n2\n3\n4\n5\n6';
alert(p.test(s)); //显示为true
alert(RegExp.rightContext.replace(/\x0A/g, '\\a')); //显示\a2\a3\a4\a5\a6
alert(RegExp.leftContext); //显示为竖的2345
alert(RegExp.rightContext); //显示为6
var p = /$/g;
var s = '1\n2\n3\n4\n5\n6';
alert(p.test(s)); //显示为true
alert(RegExp.rightContext.replace(/\x0A/g, '\\a')); //什么都不显示
alert(RegExp.leftContext); //显示为竖的123456
alert(RegExp.rightContext); //什么都不显示
var p = /^/mg;
var s = '1\n2\n3\n4\n5\n6';
alert(p.test(s)); //显示为true
alert(RegExp.rightContext.replace(/\x0A/g, '\\a')); //显示为1\a2\a3\a4\a5\a6
alert(RegExp.leftContext); //显示为竖的12345
alert(RegExp.rightContext); //显示为6
</script>
//从上例中可以看出/m影响的^$的分割方式
上面说的三个例子,/i,/g,/m分开来说的,可以排列组合使用的。个人觉得/m没有多大用处
原文地址:http://aabc99.blog.163.com/blog/static/163010810201132185918581/
一,js正则标志/g,/i,/m说明
1,/g 表示该表达式将用来在输入字符串中查找所有可能的匹配,返回的结果可以是多个。如果不加/g最多只会匹配一个
2,/i 表示匹配的时候不区分大小写
3,/m 表示多行匹配,什么是多行匹配呢?就是匹配换行符两端的潜在匹配。影响正则中的^$符号
二,实例说明
1,/g的用法
<script type="text/javascript">
str = "tankZHang (231144)"+
"tank ying (155445)";
res = str.match(/tank/); //没有加/g
alert(res); //显示一个tank
res = str.match(/tank/g); //加了/g
alert(res); //显示为tank,tank
<STRONG></script></STRONG>
2,/i的用法
<script type="text/javascript">
str = "tankZHang (231144)"+ "tank ying (155445)";
res = str.match(/zhang/);
alert(res); //显示为null
res = str.match(/zhang/i); //加了/i
alert(res); //显示为ZHang
</script>
3,/m的用法
<script type="text/javascript">
var p = /$/mg;
var s = '1\n2\n3\n4\n5\n6';
alert(p.test(s)); //显示为true
alert(RegExp.rightContext.replace(/\x0A/g, '\\a')); //显示\a2\a3\a4\a5\a6
alert(RegExp.leftContext); //显示为竖的2345
alert(RegExp.rightContext); //显示为6
var p = /$/g;
var s = '1\n2\n3\n4\n5\n6';
alert(p.test(s)); //显示为true
alert(RegExp.rightContext.replace(/\x0A/g, '\\a')); //什么都不显示
alert(RegExp.leftContext); //显示为竖的123456
alert(RegExp.rightContext); //什么都不显示
var p = /^/mg;
var s = '1\n2\n3\n4\n5\n6';
alert(p.test(s)); //显示为true
alert(RegExp.rightContext.replace(/\x0A/g, '\\a')); //显示为1\a2\a3\a4\a5\a6
alert(RegExp.leftContext); //显示为竖的12345
alert(RegExp.rightContext); //显示为6
</script>
//从上例中可以看出/m影响的^$的分割方式
上面说的三个例子,/i,/g,/m分开来说的,可以排列组合使用的。个人觉得/m没有多大用处
原文地址:http://aabc99.blog.163.com/blog/static/163010810201132185918581/
相关文章推荐
- js跳转页面
- js中json操作——函数构造法、eval、JSON.stringify、JSON.parse
- Javascript - ERR_CONTENT_LENGTH_MISMATCH
- JavaScript和CSS你未必知道的交互方法
- 一个新人对JavaScript的内容简单介绍
- js面向对象小结(一)
- JS常用的对象函数总结归纳
- extjs renderer格式化在使用 rowediting cellediting注意
- JS正则表达式大全(整理详细且实用)
- js中如何实现md5加密
- javaScript (一)数据类型
- 一个关于JSP技术的外文
- pageContext对象JSP学习
- js在页面显示错误提示信息的写法
- js中时间格式化
- way.js - 轻量级、持久化的双向绑定JS库
- JSP的9大内置对象和4大域对象
- JavaScript——2(对象)
- c#winform中使用WebKit传递js对象实现与网页交互
- extjs中第一次访问有效,第二次访问出现部分组件无法显示的,动态改变组件的label值的方法,ExtJs中组件最好少使用ID属性(推荐更多使用Name属性)