正则表达式的修饰符

在 JavaScript 中,RegExp 对象的修饰符用于控制正则表达式的匹配行为。以下是常见的修饰符及其含义:

1. g(Global,全文匹配)

  • 作用:表示全局搜索,即在整个字符串中查找所有符合的结果,而不仅仅是找到第一个匹配项后就停止。
  • 示例
    const regex = /hello/g;
    const str = "hello world, hello JavaScript!";
    console.log(str.match(regex)); // 输出 ["hello", "hello"]
    

2. i(Ignore Case,忽略大小写)

  • 作用:表示忽略大小写匹配,即在匹配时不区分大小写。
  • 示例
    const regex = /hello/i;
    const str = "Hello World!";
    console.log(str.match(regex)); // 输出 ["Hello"]
    

3. m(Multiline,多行匹配)

  • 作用:表示多行匹配模式。默认情况下,^$ 仅匹配字符串的开头和结尾。使用 m 修饰符后,它们还会匹配每一行的开头和结尾。
  • 示例
    const regex = /^hello/m;
    const str = "hello world\nhello JavaScript!";
    console.log(str.match(regex)); // 输出 ["hello"]
    

4. s(Dot All,单行模式)

  • 作用:使 . 可以匹配包括换行符在内的任何字符。默认情况下,. 不匹配换行符。
  • 示例
    const regex = /hello.*world/s;
    const str = "hello\nworld";
    console.log(regex.test(str)); // 输出 true
    

5. u(Unicode,Unicode模式)

  • 作用:启用对 Unicode 的完全支持,使得正则表达式能够正确处理 Unicode 字符。
  • 示例
    const regex = /\u{1F600}/u; // 表示查找 Unicode 编码为 1F600 的字符
    const str = "😀";
    console.log(regex.test(str)); // 输出 true
    

6. y(Sticky,粘性匹配)

  • 作用:表示“粘性”搜索,即从目标字符串的当前位置开始匹配。与 g 类似,但 y 修饰符只匹配从当前索引开始的内容,无法从中间跳过字符进行匹配。
  • 示例
    const regex = /hello/y;
    const str = "hello hello";
    regex.lastIndex = 6; // 设置搜索位置
    console.log(regex.test(str)); // 输出 true
    

修饰符总结

  • g:全局匹配。
  • i:忽略大小写。
  • m:多行模式。
  • s:单行模式(使 . 匹配包括换行符在内的所有字符)。
  • u:Unicode 模式。
  • y:粘性匹配,从目标字符串的当前位置开始匹配。

这些修饰符可以单独使用,也可以组合使用,以实现更复杂的正则表达式匹配行为。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值