正则表达式基础

1. 创建正则表达式

  1. 通过字面量的形式

    const reg = /\w/g  //匹配字母
    
  2. 通过构造函数

    const reg = new Reg('\w', 'g')
    

2. 选择符 |

const reg = /abc|edc/g    // 匹配字符串中的abc 或 edc

3. 原子组和原子表

  1. 原子组 () 正则会为原子组进行编号使用/1、/2等使用

    • 在原子组里使用:?表示该原子组不记录进组编号内,也就是说使用exec方法是获取不到该原子组匹配的内容
    const reg = /(abcdefg)/  //匹配字符串abcdefg
    

    原子组里可以使用选择符 |

    const reg = /(abc|edc )/ 
    
  1. 原子表 []

    • 原子表里使用. + 等特殊字符不需要转义,也意味着原子表里面无法使用.来匹配非空格字符
    const reg = /[abcdefg]/  //匹配abcdefg里任意一字符
    
    let str = "2022-(/)01-(/)01"  //需要匹配的字符串
    let reg = /^\d{4}[-\/]\d{2}[-\/]\d{2}$/g  
    let reg2 = /^\d{4}([-\/])\d{2}\1\d{2}$/g  //这里的\1指与上个原子组保持一致,相当于前面的原子组里的是什么后面的就匹配什么
    
    

4. 转义符 \

  • 大多数符号都需要配合使用 \ 进行转义
const reg = /\d+\.\d+/  // 匹配浮点数
  • 作为对象的参数时,与使用两个\
const reg = new RegExp("\\d+\\.\\d+")  //匹配浮点数

5. 字符边界^ $

^起始边界   、$结束边界
const reg = /^[a-z]{3,6}$/  // 匹配以字母a-z为开头a-z为结尾中间为a-z的长度为3到6w

6. 元字符

  • \d 匹配数字
  • \D 匹配非数字
  • \w 匹配字母、数字、下划线
  • \W 匹配非字母、数字、下划线
  • \s 匹配空格、换行等
  • \S 匹配非空格、换行等
  • . 匹配换行符之外的所有字符

7. 模式修饰符

  • g 全局匹配

  • s忽略换行符

  • i 不区分大小写

  • m多行匹配

    const reg = /^\s*#\d+\s+.+\s+#$/gm
    

8. 汉字与字符属性

const reg1 = /\p{L}/gu  //匹配字母
const reg2 = /\p{P}/gu  //匹配标点符号
const reg3 = /\p{sc=Han}/gu  //匹配汉字

9. lastIndex属性

  • 正则匹配后的最新的匹配项

    let reg = /\w/g;
    while ((res = reg.exec((hd)))) {
      console.log(res);
    }
    

10.区间匹配

  • [a-z]匹配a到z 之间的任意字母,加+为贪婪匹配

  • [A-Z]匹配A到Z之间的任意字母, 加+为贪婪匹配

  • [^abc] 匹配非abc的所有字符

11.匹配所有内容

  • /.+/gs 匹配所有内容
  • /[\s\S]/ 匹配所有内容 [\d\D]与[\w\W]类似

12.重复匹配

  • ?匹配一个或0个
  • *匹配0个或多个 (贪婪匹配)
  • +匹配一个或多个
  • {number, number} 匹配指定区间个数个

邮箱验证

let reg = /^[\w-]+@([\w-]+\.)+(com|org|cc|cn|net)$/i
// [email protected]

你可能感兴趣的:(正则表达式基础)