正则

正则 RegExp

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

  只要是表单提交的数据都是字符串。

  定义:

    1.var reg=new  RegExp();

    2.var reg=/格式/;

  方法:

    两大功能

      一个是匹配,匹配成功就是true,第二个是捕获,如果有就拿出来

      test()  用于匹配

      Exec()  用于捕获

    正则研究的对象是string

    修饰符:如果去匹配

      1.区不区分大小写    i代表忽略大小写

      2.全局         g代表全局匹配

      3.m代表多行匹配

    怎么使用?

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

      2.var  reg=/格式/;

      二者最后的本质都是一个对象

    字符串的方法

      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|bule|green)

    元字符

      .代表单个字符

      w代表单词字符   数字  字母  _

      W代表非单词字符

      d代表数字

      D代表非数字

      s 代表空白字符

      S代表非空白字符

      代表单词边界

      B代表非单词边界

    量词

      n+代表至少1个n的字符
      n*代表0个或多个n
      n?包含0个或1个
      n{x}包含x个n
      n{x,}包含至少x个n
      n{x,y}包含大于x个小于y个
      n$包含n结尾的字符串
      ^n包含以n开头的字符串
      ?=n指定的字符串后面紧跟的n字符串

 正则的理解

  1.正则的懒惰性

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

    

    怎么解决正则的懒惰性呢?在后面加修饰符g

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

    

   2.正则的贪婪性

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

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

      

分组捕获  正则带()  在数分组的个数是从从左往右

  var reg=/(a)(b)/ 就相当于大正则里面带了两个小正则

  第一组是(a) 第二组是(b)

  分组捕获的作用:

    1.改变优先级

    2.分组引用  1,2

          2代表和第二个分组出现一模一样的内容,1代表和第一个分组出现一模一样的内容

    3.分组捕获

      分组捕获前提是正则存在分组,不仅把大正则的内容捕获到,把小正则的内容也捕获到。

      

      怎么解除分组中的分组捕获?如果不想捕获某一个分组中的内容,在这个分组前面加上?:就可以了。

        

原文地址:https://www.cnblogs.com/qinmengyang/p/regexp.html