ES6笔记 13.正则方法、修饰符yus、UTF

阅读: 评论:0

ES6笔记 13.正则方法、修饰符yus、UTF

ES6笔记 13.正则方法、修饰符yus、UTF

正则修饰符

修饰符
全局 global;-g
大小写 ignoreCase;-i
是否以多行模式执行模式匹配 mutli-line;-m

ES6 正则扩展

  1. 声明正则的方式变化
// ES5 字面量定义正则
var reg1 = /xyz/i;
// ES5 声明正则
var reg2 = new RegExp("xyz", "i");
// ES5 传参的形式
var reg3 = new RegExp(/xyz/i);
// ES6 传参的形式,支持表达式和修饰符分开传入
var reg4 = new RegExp(/xyz/, "i");
  1. 字符串方法移动到正则中

  1. 正则修饰符的扩展 u y s
  • global(g):全局匹配;
  • ignoreCase(i):忽略大小写
  • multiline(m):多行匹配
  • sticky(y):粘连匹配

修饰符 y,sticky 粘连的意思,与全局匹配相似,与全局匹配 g(global)的唯一区别就是必须匹配连续的字符,也就是匹配第一个值要粘连第二个值(两个值相同),不然返回 null;

var str = "aaa_aa_a";
var reg1 = /a+/g;
var reg2 = /a+/y;console.(str)); // aaa
console.(str)); // aaaconsole.(str)); // aa
console.(str)); // null
  • unicode(u):识别码点匹配
  1. JS 字符串编码格式的知识
    JS 中字符串以一定的编码的方式进行储存,以 UTF-16 编码方式进行储存;
    英文是 1 个字符等于 1 个字节表示
    汉字是 1 个字符等于 2 个字节表示
    特殊字符是 1 个字符等于 4 个字节表示
    1 个字节 = 8 位 byte
  2. 码点的概念
    UTF-16 编码方式属于 Unicode 的一部分,Unicode 的每一个区可以存放 2*16 次方的字符,字节数对应编码数是 8 位,也就是 22222222 的形式;Unicode 一共分为 17 个平面,最前面的一个平面叫做(BMP)对应 16 进制的码点范围:U+0000 – U+FFFF;常用的字符都储存在第一个平面内部;
  3. 特殊字符
    可能一些特殊的字符和汉字在 16 进制码点的最大范围 U+0000 – U+FFFF 无法表示,此时 2 个字节可能表示不了特殊的字符或者汉字,此时采用 4 个字节(00|00 00|00),码点的范围是 U+D800 – U+FFFF;
  4. JS 引擎和浏览器只能够通过 UTF-16 编码方式解析 2 个字节的编码格式;
    UTF-16 并不存在下面这种编码方式,JS 引擎和浏览器并不能够解析特殊字符或者汉字;
// 错误表示方法
console.log("u20bb7");// 正确表示方法
console.log("u{20bb7}"); // {}表示特殊字符或者特殊汉字
console.log("uD842uDFB7"); // 特殊字符或者特殊汉字,通过4个字节表示一个字符;
  1. 修饰符 unicode 作用,对于特殊字符或者特殊汉字时,ES5 中并不能够准确的识别出特殊汉字并且进行匹配的 bug,而 ES6 正则的 unicode 修饰符就将对于编码方式进行优化;
console.log(/^uD83D/.test("uD83DuDC2A")); // true
console.log(/^st("uD83DuDC2A")); // false
  1. 区分量词和编码方式,通过u 标识符进行区别量词和编码方式的区别;
console.log(/a{2}/.test("aa")); // 量词
console.log(/a{2}/u.test("aa")); // 量词
console.log(/u{20bb7}/u.test("𠮷")); // 字符
  • dotAll(s):匹配一切字符

ES5 中(.)修饰符,能够匹配除了r(U2020)n(U2029)以外的所以任意字符,但是超出 UTF-16 编码最大范围的字符,并不能匹配
ES2018 中的正则修饰符 s,代表能够匹配任意字符,包括超出 UTF-16 最大编码范围的字符;

var s = "uD842uDFB7"; // 超出UTF-16编码最大返回
console.log(/^.$/.test(s)); // false// ES5
console.log(/foo.bar/.test("foonbar")); // false// ES2018
console.log(/foo.st("foonbar")); // true

source 和 flags

获取正则表达式的主体和修饰符

console.log(reg.source); // 正则主体
console.log(reg.flags); // 修饰符

rce 和 flags

获取正则表达式的主体和修饰符

console.log(reg.source); // 正则主体
console.log(reg.flags); // 修饰符

本文发布于:2024-02-04 10:14:19,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170704866954669.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:正则   笔记   方法   修饰符   yus
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23