正则

Posted on 2018-12-21 11:14  十一点半  阅读(111)  评论(0编辑  收藏  举报

正则:用于检验字符串的格式。

正则的定义:var  reg=new  RegExp()

      var  reg=/格式/

正则的方法:

  text()           匹配

  exec()    捕获

正则的修饰符:

  i      区分大小写

  g     全局匹配

  m    多行匹配

使用方法:

  var   reg=new    RegExp(“hello”,g)

  var   reg=/hel  lo/gi

字符串中与正则相关的方法:

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

  案例:        

 

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

   案例:      

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

      案例:       

 

正则的方括号:

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

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

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

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

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

元字符:

  . 代表单个字符。

  \w代表单词字符

  \W代表非单词字符。

  \d代表数字

  \D代表非数字

  \s代表空白字符

  \S代表非空白字符

  \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 开始。

解决正则的懒惰性:

正则的贪婪性:

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

解决方法: