全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

详解JavaScript RegExp对象

什么是 RegExp?

正则表达式描述了字符的模式对象。

当您检索某个文本时,可以使用一种模式来描述要检索的内容。RegExp 就是这种模式。

简单的模式可以是一个单独的字符。

更复杂的模式包括了更多的字符,并可用于解析、格式检查、替换等等。

您可以规定字符串中的检索位置,以及要检索的字符类型,等等。

RegExp对象是原生JavaScript中表示正则表达式的对象。

创建对象的方法为:var RegExp = new RegExp(pattern, attributes);

参数pattern指定正则表达式的规则或者表示正则表达式模式的字符串;

参数attributes为可选参数,表示匹配模式的修饰符。包含3个参数:

1.  i:执行对大小写不敏感匹配;

<script text="text/javascript">
  var txt = 'Hello World!'
  var reg = new RegExp('hello', 'i');
  if(reg.test(txt)) {
    console.log(txt.match(reg));
  }
</script>

2.  g:执行全局匹配(查找所有匹配项而非找到第一个匹配项后停止);

<script text="text/javascript">
  var txt = 'This is just a test.'
  var reg = new RegExp('is', 'g');//区分大小写
  var reg01 = new RegExp('is', 'gi');//不区分大小写
  if(reg.test(txt)) {
    console.log(txt.match(reg));//["is", "is"]
    console.log(txt.match(reg).length);//2
  }
</script>

3.  m:执行多行匹配(若不设置该属性,^($)只与整个被搜索字符串的开始(结尾)位置开始匹配;若设置该属性,^($)还可以与被搜索字符串的“\r”或“\n”之后位置开始匹配)。

<script type="text/javascript">
  //以下代码不能够匹配字符串"an",尽管"an"后面已经换行了,但"an"并不是字符串行的结尾。
  var txt1 = 'This is an\n apple'; 
  var reg1 = /an$/;
  console.log(txt1.match(reg1));//null
  //以下代码能够匹配到字符串"an"
  var txt2 = 'This is an\n apple';
  var reg2 = /an$/m;
  console.log(txt2.match(reg2));//["an", index: 8, input: "This is an↵ apple"]  
  //以下是多行匹配开头示例
  var txt3 = 'This is an\n apple';
  var reg3 = /^\sapp/;
  console.log(txt3.match(reg3));//null
  
  var txt4 = 'This is an\n apple';
  var reg4 = /^\sapp/m;// /^ app/m
  console.log(txt4.match(reg4));//[" app", index: 11, input: "This is an↵ apple"]
</script>

i,g,m三个修饰符可以相互组合同时使用。

以上m修饰符中的示例中var reg4 = /^\sapp/的"\"是一个转义字符,如果使用构造函数创建RegExp对象时,应将正则表达式中的"\"用"\\"进行代替:

<script type="text/javascript">
  var txt4 = 'This is an\n apple';
  var reg4 = new RegExp('^\\sapp', 'm');
  console.log(txt4.match(reg4));//[" app", index: 11, input: "This is an↵ apple"]
</script>

RegExp对象属性

1.global

  返回正则表达式是否具有"g"修饰符;

<script type="text/javascript">
  var txt = 'This is just a test';
  var reg = new RegExp('st', 'g');
  if(reg.global) {
    console.log(txt.match(reg));//["st", "st"]
  }
</script>

2.ignoreCase

  返回正则表达式是否具有"i"修饰符;

3.multiline

  返回正则表达式是否具有"m"修饰符;

4.lastIndex

  标记下一次匹配开始时所在字符串的位置;

<script type="text/javascript">
  var txt = 'If you love code, you should code everyday.';
  var reg = new RegExp('ou', 'g');
  var length = txt.match(reg).length;
  for(var i = 0; i < length; i++) {
    reg.test(txt);
    console.log(reg.lastIndex);
  }
</script>

5.source

  返回正则表达式进行模式匹配的文本或表达式,返回的文本中不包括修饰符"i","g","m",也不包括正则表达式直接量使用的定界符

<script>
  var reg1 = new RegExp('yoho', 'm');
  var reg2 = new RegExp('\\w');
  var reg3 = /\w/m;
  console.log(reg1.source);//yoho
  console.log(reg2.source);//\w
  console.log(reg3.source);//\w
</script>

RegExp对象方法

1.compile

  改变或重新编译正则表达式(Opera浏览器不支持该方法)

  对于正则表达式的重新定义,以下方法就可以实现,所以对于此方法的应用场景,我也不是很清楚

<script>
  var reg = new RegExp('ou', 'g');
  reg = /\w/;
</script>

2.exec

  检索字符串中正则表达式的匹配结果

<script>
  var txt = 'If you love code, you should code everyday.';
  var reg = new RegExp('ou', 'g');
  var length = txt.match(reg).length;
  for(var i = 0; i < length; i++) {
    console.log(reg.exec(txt));
  }
</script>

3.test

  检测字符串是否与匹配正则表达式匹配

<script>
  var txt = 'I code everyday.';
  var reg = new RegExp('code');
  console.log(reg.test(txt));//true
</script>

以上所述是小编给大家介绍的JavaScript RegExp对象,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# javascript  # regexp  # regexp对象  # 深入浅析JavaScript中的RegExp对象  # RegExp 随笔 JavaScript RegExp 对象  # 浅谈JS正则表达式的RegExp对象和括号的使用  # JS正则中的RegExp对象对象  # js正则表达式之RegExp对象之compile方法 编译正则表达式  # javascript RegExp对象(正则表达式)  # JavaScript RegExp 对象用法详解  # 正则表达式  # 修饰符  # 是一个  # 小编  # 我也  # 也不  # 还可以  # 第一个  # 在此  # 不是很  # 您可以  # 给大家  # 不支持  # 可以使用  # 可选  # 并可  # 而非  # 不包括  # 若不  # 不能够 


相关文章: 网站制作大概多少钱一个,做一个平台网站大概多少钱?  如何在阿里云部署织梦网站?  电商网站制作价格怎么算,网上拍卖流程以及规则?  如何注册花生壳免费域名并搭建个人网站?  头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?  山东网站制作公司有哪些,山东大源集团官网?  平台云上自助建站如何快速打造专业网站?  广德云建站网站建设方案与建站流程优化指南  建站之星上传入口如何快速找到?  如何在万网自助建站平台快速创建网站?  简单实现Android文件上传  如何续费美橙建站之星域名及服务?  建站之星下载版如何获取与安装?  建站之星如何实现网站加密操作?  建站之星3.0如何解决常见操作问题?  如何在企业微信快速生成手机电脑官网?  如何选择适配移动端的WAP自助建站平台?  济南专业网站制作公司,济南信息工程学校怎么样?  手机网站制作与建设方案,手机网站如何建设?  ,购物网站怎么盈利呢?  如何高效搭建专业期货交易平台网站?  大型企业网站制作流程,做网站需要注册公司吗?  在线流程图制作网站手机版,谁能推荐几个好的CG原画资源网站么?  广州建站公司哪家好?十大优质服务商推荐  常州自助建站工具推荐:低成本搭建与模板选择技巧  品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  c++如何打印函数堆栈信息_c++ backtrace函数与符号名解析【方法】  天河区网站制作公司,广州天河区如何办理身份证?需要什么资料有预约的网站吗?  企业微网站怎么做,公司网站和公众号有什么区别?  义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?  如何基于云服务器快速搭建个人网站?  制作电商网页,电商供应链怎么做?  网站制作公司,橙子建站是合法的吗?  建站为何优先选择香港服务器?  C#如何序列化对象为XML XmlSerializer用法  清除minerd进程的简单方法  如何通过VPS建站实现广告与增值服务盈利?  如何在服务器上三步完成建站并提升流量?  GML (Geography Markup Language)是什么,它如何用XML来表示地理空间信息?  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  高端网站建设与定制开发一站式解决方案 中企动力  宝塔建站后网页无法访问如何解决?  想学网站制作怎么学,建立一个网站要花费多少?  如何用景安虚拟主机手机版绑定域名建站?  如何通过二级域名建站提升品牌影响力?  网站视频怎么制作,哪个网站可以免费收看好莱坞经典大片?  建站之星客服服务时间及联系方式如何?  家具网站制作软件,家具厂怎么跑业务?  C++如何编写函数模板?(泛型编程入门)  如何挑选优质建站一级代理提升网站排名? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。