微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

正则RegExc

 

---恢复内容开始---

什么是正则,正则就是一条规则,用于检验字符串的格式,目标就是字符串

正则的定义:

  1、var reg=new  RegExp()

  2、var   reg=/格式/

正则的方法有两个功能

  1:test()用于匹配,匹配成功就是true,失败就是false

  2:exec()用于捕获,有就拿出来

正则修饰符:

  1、i:忽略大小写

  2、g:代表全局匹配

  3、M:代表多行匹配

   用的最多的就是1和2

需要使用修饰符的写法:

  1、var  reg=new  RegExp("hello",g)

  2、 var   reg=/hello/gi

跟正则有关的字符串的方法

  1、match()查找一个或多个与正则相匹配的,有就返回查找的结果,没有就是null

  

分享图片

 

 

  2、search()匹配和正则相同的字符,有就返回索引,没有就是-1

  

分享图片

  3、replace()匹配与正则相同的并替换掉,返回的替换后的字符串

  

分享图片

 

正则的方括号:

  [abc]代表查找方括号中的任何字符

  [^abc]代表查找任何一个不在方括号之间的字符

  [0-9]查找0-9之间的数字

  [a-z]查找任何小写a到小写z的字符

  [A-Z]查找任何大写A到大写Z的字符

  [A-z]查找大写A到小写z的字符

  (red|blue|green)三者中的任意一个都行

元字符:

  .点代表单个字符

  \w代表单词字符

  \W代表非单词字符

  \d代表数字

  \D代表非数字

  \s代表空白字符

  \S代表非空白字符

  \b代表单词边界

  \B代表非单词边界

  \b代表数字

  \B代表非数字

量词:

   n+  代表至少1个n的字符

    n*    代表0个或多个n

    n?  包含0个或1个n

    N{x}   包含x个n

   N{x,}包含至少x个n

     N{x,y}  包含大于等于x个小于等于y个n

   N$  包含以n结尾的字符串

      ^n    包含以n开头的字符串

   ?=n     指定字符串后面紧跟的n的字符串

正则的懒惰性

  每次在exec()中捕获的时候,只捕获第一次的内容,而不往下捕获了,这叫正则的懒惰性,每一次捕获的开始位置都是从0开始的

如何解决正则的懒惰性呢,用修饰符g来解决,全局匹配

正则的实例对象reg上有一个lastIndex属性,他是正则捕获的起始位置

分享图片

正则的贪婪性:

  每一次匹配都是按照最长的出结果,我们把这种功能叫正则的贪婪性

分享图片

 

 要解决正则的贪婪性则需要在元字符量词后面加?

 

分享图片

  

 

  

---恢复内容结束---

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐