ECMAScript 2019(ES10):数字分隔符和 BigInt

面试官:小伙子,你的数组去重方式惊艳到我了

随着 JavaScript 在现代应用程序中的普及,ECMAScript 新版本的发布成为了一个备受期待的事件。在 2019 年,ECMAScript 2019(ES10)带来了两个有趣的新特性:数字分隔符和 BigInt。在本文中,我们将深入了解这两个新特性的含义、用法和指导意义,并通过代码示例展示它们的工作原理。

数字分隔符

在日常生活中,数值很可能是以逗号或点号作为分隔符来表示的。在编写 JavaScript 代码时,这种习惯用法也会带给我们一定的便利——我们可以使用下划线来显式地分隔长数字,以提高代码的可读性。例如:

----- --------- - --------------
----- ------------- - --------------------------------------------------

在 ECMAScript 2019 中,这种“数字分隔符”被加入到了语言标准中。其基本语法如下:

----- ------ - ----------

可以在任意数字字符之间插入下划线,以分隔长数字,从而让代码更易读、更易理解。值得注意的是,数字分隔符只是在代码中间起到分隔作用,而不会影响数字本身的值。

数字分隔符的指导意义在于,大幅提高了代码可读性和可维护性,特别是在处理大数值时,使用数字分隔符来表示数值可以更加清晰地表明数字的真实含义,减少因为数字长而造成的解读错误,比如:在一份代码中,你能看出 100000000 是什么意思,但在一个大型的应用程序中,可能很难区分出这是百万还是十亿或更多。

BigInt

在 ECMAScript 2019 中,另一个值得注意的新特性是 BigInt。它是一个全新的数据类型,用来表示超出 JavaScript 数值范围(Number.MAX_SAFE_INTEGER 和 Number.MIN_SAFE_INTEGER)的数值。

使用 BigInt 很简单,只要在一个整数数值后加上 n 或者 N 即可:

----- ------ - ------------------------------------------

BigInt 除了在表示超出范围的数值时更为方便,还有一些其他的特点:它不会自动转换成普通的 Number 类型,因此没有精度丢失的隐患;与普通数值的计算不一样,BigInt 不能直接与普通数值进行计算,需要进行显示转换。

下面展示一些使用 BigInt 的代码示例:

-- -- ------ --
----- ------- - ------------
----- ------- - ------------------------------------------
----- ------- - ---------------------------------------------------

---------------------
---------------------
---------------------

-- ------ --------
----- - - ------- - ---
----- - - ------- - ---------------------
----- - - ------- - --------------------------------
----- - - ------- - ----

---------------
---------------
---------------
---------------

-- ---- ------ --
-------- ---------------- -
  --- --- - - - ---
  --- ------ - ---
  --- ---- - - ---------- - -- - -- -- ---- -
    ------ -- -------
  -
  ------ ---------------
-
----- ------- - ----------------------------
------------------------------------ -- ---------------------------

BigInt 为我们提供了一个方便的处理大数值的办法,无论是在普通计算还是在完成复杂的算术运算、密码运算或分解质因数等数学问题时,都显得尤为重要。

结论

在 ECMAScript 2019 中,数字分隔符和 BigInt 是 JavaScript 中的两个重要的特性。数字分隔符提高了代码的可读性,对于处理超出 Number 类型范围的大量数学操作,BigInt 提供了一个可恰当地解决方案。通过在代码中集成数字分隔符和 BigInt,会给我们付出更少的代价,使我们的代码更易于阅读、测试、调试和维护,而他们都是前端开发中的基本技术。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/670a2017d91dce0dc87ef63b


猜你喜欢

  • Tailwind CSS 常见的移动端适配问题及解决方法

    随着移动设备的普及,移动端适配已经成为每个前端开发者必须考虑的问题。Tailwind CSS 是一种 CSS 框架,它允许使用者为其项目构建自定义样式。但是,在移动端适配方面,很多开发者遇到了一些问题...

    6 天前
  • 如何使用 React Router 实现 SPA 应用的路由权限控制

    在现代 Web 应用程序中,路由权限控制是至关重要的。如果没有正确的路由权限控制,那么可能会导致敏感信息泄露、未经授权的访问或其他安全漏洞。在 React 开发中,React Router 是一个流行...

    6 天前
  • RESTful API 设计中的 REST 标准调研

    REST(Representational State Transfer)是一种软件架构风格,它定义了在网络上使用的一组原则和约束来创建 Web 应用程序。RESTful API(RESTful Ap...

    6 天前
  • JavaScript 写测试时摒弃逆向思维,避免使用 Chai.expect

    在编写 JavaScript 的测试用例时,我们经常使用 Chai 库的 expect 函数来进行断言。然而,使用 expect 函数确实是一种逆向思维。本文将介绍为什么要摒弃逆向思维,以及如何使用其...

    6 天前
  • Babel 编译 JSX 时的代码优化技巧

    前言 随着前端技术的不断发展,JSX 作为 React 中描述组件的一种语言,也变得越来越流行。 然而,JSX 并不能被现代的浏览器所解析,所以我们需要使用 Babel 将其转化为普通的 JavaSc...

    6 天前
  • TypeScript中的链式调用问题解析

    在前端开发中,我们常常使用链式调用来简化函数调用和代码可读性。然而,在使用 TypeScript 时,链式调用可能会出现一些问题,本文将详细分析这些问题并提供解决方案。

    6 天前
  • 选择 Serverless Framework 还是 Serverless.com?

    前言 近年来,Serverless 架构成为了云计算领域发展的热门话题。为了构建 Serverless 应用程序,我们需要一个好用的框架来帮助我们实现代码的封装和部署。

    6 天前
  • 如何在 Custom Elements 中实现拖放交互

    随着 Web 应用程序不断发展,拖放交互已经成为了现代前端开发的重要组成部分。Custom Elements 是一种现代化的 Web 组件,可以让我们通过 HTML 自定义标签和 JavaScript...

    6 天前
  • 在 PM2 中使用 node-deploy 的详细教程

    前言 PM2 是一个现代化的 Node.js 进程管理工具,而 node-deploy 则是一款非常强大的 Node.js 自动化部署工具。结合使用这两个工具可以让你的 Node.js 应用部署和管理...

    6 天前
  • 在 ECMAScript 2020 中使用 flattening 操作符来简化方法调用

    ECMAScript 2020 中的 flattening 操作符是一种强大的技术,它可以帮助前端开发人员简化方法调用。它可以让你在多维嵌套数据结构中进行扁平化方法调用,从而使代码更加简洁、易于维护。

    6 天前
  • 在 ES12 中使用 ArrayBuffer.transfer 方法处理二进制数据

    随着 Web 技术的发展和进步,越来越多的 Web 应用需要处理二进制数据。在以往,我们经常使用 ArrayBuffer 和 DataView 来处理二进制数据。在 ES12 中,新增了 ArrayB...

    6 天前
  • 解锁 Mongoose Schema 的锁定模式

    Mongoose 是一个优秀的 Node.js 框架,它提供了操作 MongoDB 数据库的强大工具。其中,Mongoose Schema 是定义数据结构格式的重要组件。

    6 天前
  • ESLint 检查 Vue.js 组件代码中存在的问题

    ESLint 检查 Vue.js 组件代码中存在的问题 在 Vue.js 中编写组件是很常见的事情。然而,编写和维护大量组件可能会很困难。ESLint 是一种流行的 JavaScript lint 工...

    6 天前
  • Headless CMS 在跨平台应用开发中的应用实践

    前端类技术正在飞速发展,开发人员需要掌握不断增加的技术和工具。其中,Headless CMS 是一种新兴的技术,可帮助开发人员在应用程序中更好地管理数据。在本文中,我们将探讨 Headless CMS...

    6 天前
  • MongoDB 索引性能优化的方法

    摘要 MongoDB 是一个流行的 NoSQL 数据库,在前端开发中广泛使用。它的索引机制是其高性能的基石之一。但是,如果索引使用不当,将会降低查询性能,甚至造成数据库崩溃。

    6 天前
  • 高性能编程之 IO 多路复用技术探究

    在现代 web 开发中,前端性能的提高是至关重要的。在接受大量请求的网络服务中,I/O 操作通常是性能瓶颈。对于输入/输出密集型任务,可以使用 IO 多路复用技术来大大提高性能。

    6 天前
  • Redis 分布式场景下的请求合并技巧

    Redis 分布式场景下的请求合并技巧 前言 在分布式系统中,请求合并是一种常用的优化手段,可以减少网络传输的次数和开销,从而提高系统的性能和吞吐量。Redis 作为一个高性能的缓存和数据存储系统,也...

    6 天前
  • SSE 实践:在微信中使用 Server-sent Events 实现实时消息推送

    SSE 实践:在微信中使用 Server-sent Events 实现实时消息推送 在现代 Web 应用程序中,实时通信已成为一个必不可少的需求。在无数场景中,像社交网络应用、在线聊天室、实时监控和协...

    6 天前
  • TypeScript 中如何优雅地处理异常情况

    对于前端开发人员来说,处理异常情况是一项必不可少的技能。当我们编写代码时,可能会出现各种各样的错误情况,如网络错误、类型错误、无效参数等。如果不正确地处理这些错误,很容易导致程序崩溃。

    6 天前
  • Docker Swarm 健康检查及常见问题解决

    Docker Swarm 是 Docker 官方推出的容器编排工具,它可以轻松管理多台 Docker 节点,将多个 Docker 容器部署到不同的节点上。使用 Docker Swarm,我们可以将多个...

    6 天前

相关推荐

    暂无文章