ES6 正则的扩展(十九)

打印 上一主题 下一主题

主题 549|帖子 549|积分 1657

1. 正则表达式字面量改进

特性:在 ES6 中,正则表达式字面量允许在字符串中使用斜杠(/)作为分隔符。
用法:简化正则表达式的誊写。
  1. const regex1 = /foo/;
  2. const regex2 = /foo/g; // 全局搜索
复制代码
2. u 修饰符(Unicode)

特性:u 修饰符允许正则表达式精确处置惩罚 Unicode 字符。
用法:确保正则表达式在处置惩罚多字节字符时表现精确。
  1. const regex = /foo/u;
  2. console.log(regex.test("foö")); // 输出:false
复制代码
3. y 修饰符(Sticky)

特性:y 修饰符使正则表达式在搜索时“粘”在每个匹配的开始位置。
用法:进行连续的匹配搜索。
  1. const text = "abcabc";
  2. const regex = /abc/y;
  3. let match;
  4. while ((match = regex.exec(text)) !== null) {
  5.     console.log(`Found ${match[0]} at index ${match.index}`);
  6. }
  7. // 输出:
  8. // Found abc at index 0
  9. // Found abc at index 3
复制代码
4. 新增的正则表达式方法

特性:String.prototype.match(), String.prototype.replace(), String.prototype.search(), 和 String.prototype.split() 现在可以担当正则表达式字面量。
用法:直接使用正则表达式进行字符串处置惩罚。
  1. const text = "Hello World";
  2. const regex = /Hello/;
  3. console.log(text.match(regex)); // 输出:["Hello"]
  4. console.log(text.replace(regex, "Hi")); // 输出:"Hi World"
  5. console.log(text.search(regex)); // 输出:0
  6. console.log(text.split(regex)); // 输出:["", " World"]
复制代码
5. flags 属性

特性:正则表达式对象现在有一个 flags 属性,返回正则表达式的修饰符。
用法:获取正则表达式使用的修饰符。
  1. const regex = /foo/g;
  2. console.log(regex.flags); // 输出:"g"
复制代码
6. dotAll 模式(点字符匹配全部)

特性:当设置了 s 修饰符(dotAll)时,点字符(.)可以匹配包括换行符在内的任何字符。
用法:进行多行匹配。
  1. const text = "foo\nbar";
  2. const regex = /bar/s; // 使用 dotAll 模式
  3. console.log(regex.test(text)); // 输出:true
复制代码
7. hasIndices 属性

特性:hasIndices 属性用于指示正则表达式是否捕获分组。
用法:检查正则表达式是否包含捕获组。
  1. const regex1 = /foo/;
  2. const regex2 = /foo(bar)/;
  3. console.log(regex1.hasIndices); // 输出:false
  4. console.log(regex2.hasIndices); // 输出:true
复制代码
8. Symbol.match, Symbol.replace, Symbol.search, Symbol.split

特性:这些 Symbol 属性允许使用正则表达式进行字符串匹配、替换、搜索和分割。
用法:提供一种更灵活的方式来处置惩罚字符串。
  1. const text = "Hello World";
  2. const regex = /world/i;
  3. console.log(text[Symbol.match](regex)); // 输出:["World"]
  4. console.log(text[Symbol.replace](regex, "there")); // 输出:"Hello there"
  5. console.log(text[Symbol.search](regex)); // 输出:4
  6. console.log(text[Symbol.split](regex)); // 输出:["Hello ", ""]
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

正序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

泉缘泉

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表