javascript正则表达式标记中/g /i /m的用法,以及实例

 更新时间:2020年02月24日 22:36:56   投稿:mdxy-dxy  
正则的思想都是一样的,但是具体的写法会有所不同,在这里提到的/g,/i,/m在其他的地方也许就不能用了,需要的朋友可以参考下

一,js正则标志/g,/i,/m说明

1,/g (globle)表示该表达式将用来在输入字符串中查找所有可能的匹配,全文查找出现的所有匹配字符,返回的结果可以是多个。如果不加/g最多只会匹配一个
2,/i (ignorCase)表示匹配的时候不区分大小写,
忽略大小写,注意仅是忽略大小写,并不忽略全半角。
3,/m (mutiple)表示多行匹配,多行查找什么是多行匹配呢?就是匹配换行符两端的潜在匹配。影响正则中的^$符号
m 影响 ^、$。
若不指定 m,则:^ 只在字符串的最开头,$ 只在字符串的最结尾。即:匹配整个串的开始和结束
若指定 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 
</script> 

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没有多大用处

补充说明:

\n匹配一个换行符。等价于 \x0a 和 \cJ

rightContext

RegExp.rightContext ($')

该特性是非标准的,请尽量不要在生产环境中使用它!

rightContext 非标准属性是正则表达式的静态和只读属性,含有最新匹配的右侧子串。 RegExp.$' 是这个属性的别名。

语法

RegExp.rightContext
RegExp["$'"]

描述
rightContext 属性是静态的,不是正则表达式独立对象的属性。反之,你应始终将其使用为 RegExp.rightContext 或者 RegExp["$'"]。

rightContext 属性的值是只读的,并且会在匹配成功时修改。

你不能使用属性访问器(RegExp.$')来使用简写的别名,因为解析器在这里会将其看做字符串的开始,并抛出 SyntaxError。使用 方括号符号来访问属性。

示例
使用 rightContext 和 $'

var re = /hello/g;
re.test('hello world!');
RegExp.rightContext; // " world!"
RegExp["$'"]; // " world!"

leftContext 非标准属性是正则表达式的静态和只读属性,含有最新匹配的左侧子串。 RegExp.$` 是这个属性的别名。

语法

RegExp.leftContext
RegExp['$`']

描述

leftContext 属性是静态的,不是正则表达式独立对象的属性。反之,你应始终将其使用为 RegExp.leftContext 或者 RegExp['$`']。
leftContext 属性的值是只读的,并且会在匹配成功时修改。

你不能使用属性访问器(RegExp.$`)来使用简写的别名,因为解析器在这里会将其看做模板字符串的开始,并抛出 SyntaxError 。使用 方括号符号来访问属性。

示例
使用 leftContext 和 $`

var re = /world/g;
re.test('hello world!');
RegExp.leftContext; // "hello "
RegExp['$`']; // "hello "

规范

非标准。并不是任何现行规范的一部分。

相关文章

  • 正则表达式中关于对原生字符串的简单理解

    正则表达式中关于对原生字符串的简单理解

    正则表达式即使用一个字符串来描述、匹配一系列某个语法规则的字符串,下面这篇文章主要给大家介绍了关于正则表达式中关于对原生字符串的简单理解,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-08-08
  • 在ASP中用正则表达式对象来校验数据的合法性

    在ASP中用正则表达式对象来校验数据的合法性

    我们在制作网站的时候,需要对用户输入的数据进行验证,前端是辅助用户方便填写,后端才是真正的安全过滤,正则表达式对于一些数据校验都是比较常见的不只asp中需要,php也需要,这里脚本之家小白就为大家简单介绍一下
    2006-06-06
  • 深入浅出解析正则表达式-替换原则

    深入浅出解析正则表达式-替换原则

    本文给大家分享的正则表达式的替换原则,这里讲到的替换是只能在替换模式中识别的语言元素。感兴趣的朋友跟着小编一起学习吧
    2015-09-09
  • Linux下如何使用grep命令查找带有tab(退格)的字符

    Linux下如何使用grep命令查找带有tab(退格)的字符

    本文给大家介绍linux下如何使用grep命令查找带有tab(退格)的字符,涉及到linux grep 查找带有tab的字符方面的知识,对linux grep tab感兴趣的朋友可以参考下本篇文章
    2015-10-10
  • grep正则表达式匹配中括号的方法实例

    grep正则表达式匹配中括号的方法实例

    正则中的括号有不同的意义,不同的字符在括号中也有不同的意义,下面这篇文章主要给大家介绍了关于grep正则表达式匹配中括号的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-09-09
  • 正则表达式解二元方程式代码

    正则表达式解二元方程式代码

    看到了这文我震惊了,正则能解二元方程式~~,需要的朋友可以看下
    2012-10-10
  • 基于正则表达式实现UL下LI的样式替换功能

    基于正则表达式实现UL下LI的样式替换功能

    这篇文章主要介绍了基于正则表达式实现UL下LI的样式替换功能,涉及javascript使用正则表达式进行页面元素属性动态操作的相关实现技巧,需要的朋友可以参考下
    2017-05-05
  • bash 中用于grep的正则表达式

    bash 中用于grep的正则表达式

    正则表达式是一类用于匹配文本的表达方式,常用于grep命令中表达检索条件。接下来通过本文给大家介绍bash 中用于grep的正则表达式,需要的朋友参考下吧
    2017-03-03
  • Python爬虫正则表达式常用符号和方法

    Python爬虫正则表达式常用符号和方法

    python语言虽然诞生很久,但是也是最近几年才火起来的。在python语言中,我们经常会用到python爬虫的正则表达式,下面小编通过本篇文章给大家介绍python爬虫正则表达式常用的符号和方法,以及具体用法,感兴趣的童鞋快来看看吧
    2015-10-10
  • JavaScript replace new RegExp使用介绍

    JavaScript replace new RegExp使用介绍

    这篇文章主要介绍了JavaScript replace new RegExp使用介绍,需要的朋友可以参考下
    2016-05-05

最新评论