Skip to content

正则

正则表达式用于定义一些字符串的规则:

计算机可以根据正则表达式,来检查一个字符串是否符合规则 *获取将字符串中符合规则的内容提取出来。

创建正则表达式

  • var reg = new RegExp("正则","匹配模式");//参数是字符串,可以写变量;构造函数创建更加灵活

  • var reg = /正则表达式/匹配模式 //参数不需要加引号;创建更加简单 遇到\转义,通过new创建,因为里面参数是字符串,要先\转义成对应要的正则表达式,再把正则表达式\转义成实际代表的字符串

字符串和正则相关的方法

  • split(""),参数可以是正则表达式,split方法返回一个数组

  • search()

    • 可以搜索字符串中是否含有指定内容
    • 如果搜索到指定内容,则会返回第一次出现的索引,如果没有搜索到返回-1
    • 它可以接受一个正则表达式作为参数,然后会根据正则表达式去检索字符串
    • search()只会查找第一个,即使设置全局匹配也没用
    js
    str = "hello abc hello aec afc";
      /*
      * 搜索字符串中是否含有abc 或 aec 或 afc
      */
      result = str.search(/a[bef]c/);
    
      //console.log(result);
    ``
    str = "hello abc hello aec afc";
      /*
      * 搜索字符串中是否含有abc 或 aec 或 afc
      */
      result = str.search(/a[bef]c/);
    
      //console.log(result);
    ``
  • match()

    • 可以根据正则表达式,从一个字符串中将符合条件的内容提取出来
    • 默认情况下我们的match只会找到第一个符合要求的内容,找到以后就停止检索
    • 我们可以设置正则表达式为全局匹配模式,这样就会匹配到所有的内容
    • 可以为一个正则表达式设置多个匹配模式,且顺序无所谓
    • match()会将匹配到的内容封装到一个数组中返回,即使只查询到一个结果
    js
    str = "1a2a3a4a5e6f7A8B9C";
    
    result = str.match(/[a-z]/ig);
    
    //console.log(result[2]);
    str = "1a2a3a4a5e6f7A8B9C";
    
    result = str.match(/[a-z]/ig);
    
    //console.log(result[2]);
  • replace()

    • 可以将字符串中指定内容替换为新的内容
    • 参数:
      1. 被替换的内容,可以接受一个正则表达式作为参数
      2. 新的内容
    • 默认只会替换第一个
    js
    //result = str.replace(/[a-z]/gi , "@_@");
    result = str.replace(/[a-z]/gi , "");
    
    //console.log(result);
    //result = str.replace(/[a-z]/gi , "@_@");
    result = str.replace(/[a-z]/gi , "");
    
    //console.log(result);

语法:

  • 匹配模式:

    i:忽略大小写
    g:全局匹配模式

  • 设置匹配模式时,可以都不设置,也可以设置1个,也可以全设置,设置时没有顺序要求

  • 方法: test()

    • 可以用来检查一个字符串是否符合正则表达式
    • 如果符合返回true,否则返回false
  • 正则语法

    • 语法
      | 或
      [] 或
      [^ ] 除了
      [a-z] 小写字母
      [A-Z] 大写字母
      [A-z] 任意字母
      [0-9] 任意数字

    • 量词 {n} 正好n次
      {m,n} m-n次
      {m,} 至少m次
      + 至少1次 {1,}
      ? 0次或1次 {0,1}
      * 0次或多次

    • 转义字符 \ 在正则表达式中使用\作为转义字符
      \. 表示.
      \\ 表示\ . 表示任意字符
      \w 相当于[A-z0-9_]
      \W 相当于[^A-z0-9_]
      \d 任意数字
      \D 除了数字
      \s 空格
      \s+ 单个的空白字符,换行符也算单个的空白字符
      \S 除了空格
      \b 单词边界****
      \B 除了单词边界

    • ^ 表示开始

    • $ 表示结束