ES6笔记 13.正则方法、修饰符yus、UTF_16编码方式

2023-12-07 11:50

本文主要是介绍ES6笔记 13.正则方法、修饰符yus、UTF_16编码方式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

正则修饰符

修饰符
全局 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. 字符串方法移动到正则中

image.png

  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.log(reg1.exec(str)); // aaa
console.log(reg2.exec(str)); // aaaconsole.log(reg1.exec(str)); // aa
console.log(reg2.exec(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("\uD842\uDFB7"); // 特殊字符或者特殊汉字,通过4个字节表示一个字符;
  1. 修饰符 unicode 作用,对于特殊字符或者特殊汉字时,ES5 中并不能够准确的识别出特殊汉字并且进行匹配的 bug,而 ES6 正则的 unicode 修饰符就将对于编码方式进行优化;
console.log(/^\uD83D/.test("\uD83D\uDC2A")); // true
console.log(/^\uD83D/u.test("\uD83D\uDC2A")); // 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 = "\uD842\uDFB7"; // 超出UTF-16编码最大返回
console.log(/^.$/.test(s)); // false// ES5
console.log(/foo.bar/.test("foo\nbar")); // false// ES2018
console.log(/foo.bar/s.test("foo\nbar")); // true

source 和 flags

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

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

rce 和 flags

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

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

这篇关于ES6笔记 13.正则方法、修饰符yus、UTF_16编码方式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/465764

相关文章

Spring Security方法级安全控制@PreAuthorize注解的灵活运用小结

《SpringSecurity方法级安全控制@PreAuthorize注解的灵活运用小结》本文将带着大家讲解@PreAuthorize注解的核心原理、SpEL表达式机制,并通过的示例代码演示如... 目录1. 前言2. @PreAuthorize 注解简介3. @PreAuthorize 核心原理解析拦截与

一文详解JavaScript中的fetch方法

《一文详解JavaScript中的fetch方法》fetch函数是一个用于在JavaScript中执行HTTP请求的现代API,它提供了一种更简洁、更强大的方式来处理网络请求,:本文主要介绍Jav... 目录前言什么是 fetch 方法基本语法简单的 GET 请求示例代码解释发送 POST 请求示例代码解释

Feign Client超时时间设置不生效的解决方法

《FeignClient超时时间设置不生效的解决方法》这篇文章主要为大家详细介绍了FeignClient超时时间设置不生效的原因与解决方法,具有一定的的参考价值,希望对大家有一定的帮助... 在使用Feign Client时,可以通过两种方式来设置超时时间:1.针对整个Feign Client设置超时时间

C/C++错误信息处理的常见方法及函数

《C/C++错误信息处理的常见方法及函数》C/C++是两种广泛使用的编程语言,特别是在系统编程、嵌入式开发以及高性能计算领域,:本文主要介绍C/C++错误信息处理的常见方法及函数,文中通过代码介绍... 目录前言1. errno 和 perror()示例:2. strerror()示例:3. perror(

CSS Padding 和 Margin 区别全解析

《CSSPadding和Margin区别全解析》CSS中的padding和margin是两个非常基础且重要的属性,它们用于控制元素周围的空白区域,本文将详细介绍padding和... 目录css Padding 和 Margin 全解析1. Padding: 内边距2. Margin: 外边距3. Padd

CSS will-change 属性示例详解

《CSSwill-change属性示例详解》will-change是一个CSS属性,用于告诉浏览器某个元素在未来可能会发生哪些变化,本文给大家介绍CSSwill-change属性详解,感... will-change 是一个 css 属性,用于告诉浏览器某个元素在未来可能会发生哪些变化。这可以帮助浏览器优化

CSS去除a标签的下划线的几种方法

《CSS去除a标签的下划线的几种方法》本文给大家分享在CSS中,去除a标签(超链接)的下划线的几种方法,本文给大家介绍的非常详细,感兴趣的朋友一起看看吧... 在 css 中,去除a标签(超链接)的下划线主要有以下几种方法:使用text-decoration属性通用选择器设置:使用a标签选择器,将tex

C++变换迭代器使用方法小结

《C++变换迭代器使用方法小结》本文主要介绍了C++变换迭代器使用方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、源码2、代码解析代码解析:transform_iterator1. transform_iterat

C++中std::distance使用方法示例

《C++中std::distance使用方法示例》std::distance是C++标准库中的一个函数,用于计算两个迭代器之间的距离,本文主要介绍了C++中std::distance使用方法示例,具... 目录语法使用方式解释示例输出:其他说明:总结std::distance&n编程bsp;是 C++ 标准

前端高级CSS用法示例详解

《前端高级CSS用法示例详解》在前端开发中,CSS(层叠样式表)不仅是用来控制网页的外观和布局,更是实现复杂交互和动态效果的关键技术之一,随着前端技术的不断发展,CSS的用法也日益丰富和高级,本文将深... 前端高级css用法在前端开发中,CSS(层叠样式表)不仅是用来控制网页的外观和布局,更是实现复杂交