使用 ECMAScript 2017 的 Array.prototype.includes() 方法实现 JavaScript 中的数组元素包含判断及常见问题解决方式

在 JavaScript 中,数组是一种非常常见的数据结构。我们经常需要对数组进行包含判断,即判断数组中是否包含某个特定的元素。在早期的 JavaScript 版本中,实现这种判断一般使用 Array.prototype.indexOf() 方法,但是该方法存在一些问题,如需要手动判断返回值是否为 -1,不能判断 NaN 等。随着 ECMAScript 2017 的发布,新增了 Array.prototype.includes() 方法来解决这些问题。

1. Array.prototype.includes() 方法的基本用法

Array.prototype.includes() 方法用来判断数组中是否包含某个特定的元素,返回值为布尔类型。其基本语法如下所示:

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

其中,searchElement 参数为需要在数组中查找的元素,fromIndex 参数为可选参数,表示从哪个索引开始查找元素,如果不指定该参数,则默认从索引 0 开始查找。

例如,判断数组 [1, 2, 3] 中是否包含元素 2,可以采用以下代码:

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

2. Array.prototype.includes() 方法的常见问题解决方式

与早期的 Array.prototype.indexOf() 方法相比,Array.prototype.includes() 方法有以下优势:

2.1 不需要手动判断返回值是否为 -1

Array.prototype.indexOf() 方法在未找到元素时返回 -1,而我们经常需要手动判断返回值是否为 -1。例如,判断数组 [1, 2, 3] 中是否包含元素 4,可以采用以下代码:

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

而使用 Array.prototype.includes() 方法,代码更加简洁易懂:

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

2.2 能够判断 NaN 元素

NaN(Not a Number)是一种特殊的数值类型,如果使用 Array.prototype.indexOf() 方法查找 NaN 元素,会出现错误的结果:

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

这是因为 JavaScript 中的 NaN 和任意值都不相等,甚至包括自身。使用 Array.prototype.includes() 方法,能够正确地判断 NaN 元素:

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

3. 示例代码

下面是一个完整的示例代码,演示了如何使用 Array.prototype.includes() 方法实现数组元素包含判断:

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

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

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

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

4. 总结

使用 ECMAScript 2017 的 Array.prototype.includes() 方法可以更加方便地实现 JavaScript 中的数组元素包含判断。虽然以前的 Array.prototype.indexOf() 方法也能实现相同的功能,但是在一些特殊情况下会出现问题。同时,Array.prototype.includes() 方法还可以帮助我们避免手动判断返回值是否为 -1 和解决 NaN 元素判断的问题,使代码更加简洁易懂。

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


猜你喜欢

  • Deno 中使用 async 和 await 的最佳实践及常见问题解答

    Deno 是一个现代的 JavaScript 运行时,它使用 V8 引擎,并提供了更加安全、稳定和可靠的开发环境。在 Deno 中,我们可以使用 async 和 await 来处理异步任务,这是一种非...

    1 年前
  • 在 Jest 测试框架中如何 mock 掉 redux-thunk 中 dispatch 的参数

    在开发前端项目时,Jest 是一个常用的测试框架,而 redux-thunk 则是 Redux 应用中常用的中间件,用于处理异步操作。在使用 Jest 进行单元测试时,我们经常需要模拟函数的返回值或处...

    1 年前
  • Docker 容器中设置静态 IP 地址的方法

    在使用 Docker 部署应用时,我们通常需要为容器分配一个唯一的 IP 地址以便于网络通信。默认情况下,Docker 会自动为容器分配一个动态 IP 地址,但有时我们需要为容器指定一个静态 IP 地...

    1 年前
  • Sequelize ORM 实践技巧:如何优化 Sequelize 的连接池配置?

    在使用 Sequelize ORM 进行开发时,我们经常需要与数据库进行交互,而对于连接池的优化配置,可以大大提高应用性能与稳定性。 什么是连接池? 连接池是指在应用启动时创建的一组连接,应用程序可以...

    1 年前
  • 常见问题:使用 LESS 中字体图标的方法

    常见问题:使用 LESS 中字体图标的方法 前言 随着 Web 前端技术的发展,越来越多的网站开始使用字体图标来代替传统的小图片,这不仅加快了网站的加载速度,还使得开发人员能够更加灵活地进行布局和排版...

    1 年前
  • ECMAScript 2020: String.prototype.trimStart 和 String.prototype.trimEnd 方法简介

    在 ECMAScript 2020 中引入的两个新方法 String.prototype.trimStart 和 String.prototype.trimEnd,分别用于消除字符串开头和结尾的空字符...

    1 年前
  • RxJS 中组合多个数据流的方法及应用

    RxJS 是一个开源的响应式编程库,它提供了一种便捷的方式来处理异步数据流和事件。其中非常重要的一个功能就是组合多个数据流。本文将介绍 RxJS 中组合多个数据流的方法及其应用,并提供实际的示例。

    1 年前
  • 更新 Redux 至 v4.x 后,它的改变有哪些?

    Redux 是一个非常流行的状态管理库,它的稳定性和可靠性一直备受开发者的认可和青睐。最近,Redux 发布了一个新的版本——v4.x,这个版本相比于之前的版本更加稳定且有了很多的重大改动。

    1 年前
  • 在 Tailwind 项目中常用的 Box Shadow 设计代码

    如果你是一名前端开发者,你可能已经听说过 Tailwind CSS 这个 CSS 框架。Tailwind CSS 是一个基于类的 CSS 工具包,它允许你快速构建响应式和可定制的 Web 应用程序。

    1 年前
  • Mocha 测试套件中的 "slow" 和 "timeout" 选项有何作用?

    在前端 Web 开发中,测试是确保我们代码质量的重要手段。而 Mocha 就是一款广泛使用的 JavaScript 测试框架,它提供了许多选项来优化测试执行过程,其中包括 “slow” 和 “time...

    1 年前
  • MongoDB 中的数据聚合查询技术分享

    MongoDB 是一种流行的 NoSQL 数据库,它支持多种数据模型,并且可以非常高效地处理大量数据。MongoDB 的聚合查询(Aggregation)功能是一个强大的工具,它可以通过将多个文档合并...

    1 年前
  • 理解 ECMAScript 2019 中的尾逗号并在 JavaScript 代码中使用它

    在 ECMAScript 2019 规范中,引入了对尾逗号的支持。尾逗号指的是在一个对象、数组或函数参数列表的最后一项后面添加一个逗号。虽然这看起来像是个小细节,但它可以带来许多好处,并且在开发流程中...

    1 年前
  • Hapi 框架结合 Pino 日志库优化 Node 应用的记录和输出

    Node.js 是一种高效的 Web 应用开发技术,但为了确保应用在运行过程中能够稳定、可靠并且优化性能,需要配置适当的日志系统。在 Node.js 上常见的日志库中,Pino 是一个相当流行的选择,...

    1 年前
  • Koa.js 使用 Log4js 记录日志的最佳实践

    简介 Koa.js 是一款轻量级的 Node.js Web 框架。而 Log4js 是一个功能强大的 JavaScript 日志工具。在实际开发中,使用 Log4js 进行日志记录是非常常见的做法。

    1 年前
  • 如何在 Jest 测试框架中 Mock Window.location.href

    在前端开发中,我们经常需要使用单元测试来确保代码质量和稳定性。Jest 是一个非常流行的 JavaScript 测试框架,它可以帮助我们编写简洁高效的测试用例。 然而,有时候我们会遇到一些特殊情况,例...

    1 年前
  • Serverless 部署踩坑记

    什么是 Serverless? Serverless 是一种云计算架构,它让开发者可以在完全无需考虑服务器管理的情况下编写和部署应用程序。相比于传统的服务器架构,Serverless 可以大大降低维护...

    1 年前
  • 如何使用 Fastify 和 Pug 实现快速的 Web 页面渲染

    Fastify 是一个快速和低开销的 Web 框架,而 Pug(旧名为 Jade)是一个流行的模板引擎,用于生成 HTML。 这两者结合使用可以让 Web 页面渲染更加快速,并且可以方便地添加动态内容...

    1 年前
  • 在 Vue.js 中使用 RxJS 优化异步数据流处理

    在 Vue.js 应用中,我们经常需要处理各种异步数据流,比如从后端 API 获取数据、用户输入事件等等。这些异步数据流的处理不仅非常关键,而且通常也很复杂。为了帮助开发者更好地处理异步数据流,本文介...

    1 年前
  • 如何在 Mocha 测试套件中使用 “reporters” 选项来生成测试报告?

    Mocha 是一个流行的 JavaScript 测试框架。如果你正在编写 JavaScript 应用程序或库,那么你可能需要测试它们以确保它们按预期工作。Mocha 使得编写和运行这些测试变得非常容易...

    1 年前
  • Next.js 项目中如何使用 Axios 来进行 HTTP 请求操作?

    在开发 Next.js 项目时,我们经常需要与后端服务进行 HTTP 请求操作。Axios 是一个十分流行的 JavaScript HTTP 客户端库,它可以帮助我们轻松地发送 HTTP 请求并处理响...

    1 年前

相关推荐

    暂无文章