JavaScript如何用includes检查数组包含

includes() 方法能快速判断数组是否包含特定元素,返回布尔值。1. 使用方式简单,直接传入要查找的值即可,如 fruits.includes(‘banana’) 返回 true;2. 支持从指定索引开始查找,如 fruits.includes(‘apple’, 2) 返回 false;3. 可正确识别 nan,numbers.includes(nan) 返回 true;4. 与 indexof() 相比更简洁直观,且处理 nan 更友好;5. 对对象或数组等复杂数据类型仅比较引用,不比较内容,需用 some() 配合自定义函数实现内容匹配;6. 适用于权限判断、表单验证、ui状态切换、数据过滤等场景,代码可读性高且高效便捷。

JavaScript如何用includes检查数组包含

当我们需要快速判断一个数组里有没有某个特定元素时,JavaScript的includes()方法无疑是我的首选。它直接、简洁,返回一个布尔值,让你一眼就知道结果。

JavaScript如何用includes检查数组包含

解决方案

includes() 方法的工作原理非常直观:你给它一个值,它就去数组里找。找到了,返回 true;没找到,返回 false。它甚至可以接受第二个参数,指定从哪个索引开始搜索,这在某些特定场景下还挺方便的。

const fruits = ['apple', 'banana', 'orange', 'grape'];// 检查数组是否包含 'banana'console.log(fruits.includes('banana')); // 输出: true// 检查数组是否包含 'kiwi'console.log(fruits.includes('kiwi'));   // 输出: false// 从索引2('orange')开始检查是否包含 'apple'console.log(fruits.includes('apple', 2)); // 输出: false (因为'apple'在索引0)// includes() 对 NaN 的处理非常友好,这是 indexOf() 做不到的const numbers = [1, 2, NaN, 4];console.log(numbers.includes(NaN)); // 输出: true

includes() 与 indexOf() 有何不同?为何选择 includes()?

我记得以前,要判断数组是否包含某个元素,我们通常会用 indexOf() 方法,然后判断结果是否不等于 -1。比如 arr.indexOf(item) !== -1。这当然能达到目的,但总觉得有点绕,不够直接。includes() 的出现,简直是让代码意图瞬间清晰起来。

立即学习“Java免费学习笔记(深入)”;

JavaScript如何用includes检查数组包含

它们最核心的区别就在于返回值的类型:indexOf() 返回的是找到元素的第一个索引,如果没找到就返回 -1;而 includes() 直接返回一个 boolean 值 (truefalse)。这让我们的条件判断语句变得异常简洁。

更关键的一点是,includes() 在处理 NaN(Not-a-Number)时表现得更加“智能”或者说符合直觉。indexOf() 无法找到数组中的 NaN,因为它内部使用的是严格相等 (===),而 NaN === NaN 的结果是 false。但 includes() 却能正确识别 NaN。对我来说,这一点就足以让我在需要判断包含时优先选择 includes()

JavaScript如何用includes检查数组包含

includes() 如何处理复杂数据类型或对象?

这里有个小坑,也是我刚开始用 includes() 时常犯的错误,或者说容易产生误解的地方。includes() 方法在比较时,使用的是严格相等 (===)。这意味着,当你尝试检查数组是否包含一个对象或另一个数组时,它只有在引用的是内存中完全相同的那个对象或数组实例时,才会返回 true

举个例子:

const users = [{ id: 1, name: 'Alice' }, { id: 2, name: 'Bob' }];const alice = { id: 1, name: 'Alice' };const bob = users[1]; // 直接引用了数组中的对象console.log(users.includes(alice)); // 输出: false// 尽管内容看起来一样,但 'alice' 是一个新的对象,和数组里的不是同一个引用console.log(users.includes(bob));   // 输出: true// 'bob' 变量直接引用了 users 数组中的第二个对象,所以是同一个实例

所以,如果你想检查数组里是否包含一个“内容相同”但“引用不同”的对象,includes() 就帮不上忙了。这时候,你可能需要 Array.prototype.some() 方法,结合一个自定义的比较函数来遍历数组,判断对象的某个属性是否匹配。

// 如果要检查内容,而不是引用const hasAliceContent = users.some(user => user.id === alice.id && user.name === alice.name);console.log(hasAliceContent); // 输出: true

理解这个引用比较的特性非常重要,能避免很多看似奇怪的 bug。

在实际项目中,何时应该使用 includes()?

includes() 在实际项目中的应用场景非常广泛,只要你的需求是“检查某个值是否存在于一个简单数组中”,它就是最合适的工具

比如:

权限判断: 用户角色数组 userRoles 中是否包含 admin 权限?userRoles.includes('admin')表单验证: 用户输入的标签 tag 是否在预定义的允许标签列表 allowedTags 中?allowedTags.includes(tag)UI状态切换: 某个元素是否被选中(假设选中项ID存储在数组中)?selectedItemIds.includes(currentId)数据过滤: 快速判断某个 ID 是否在黑名单或白名单数组里。

它最大的优点就是简洁和可读性。对于那些不需要复杂比较逻辑,仅仅是判断元素是否存在的情况,includes() 提供了最直接的语义表达。当然,如果你的数组非常庞大,并且需要进行大量此类操作,你可能需要考虑 Set 数据结构,它的 has() 方法在查找性能上会更有优势,但那又是另一个话题了。对于大多数日常使用场景,includes() 已经足够高效和便利了。

以上就是JavaScript如何用includes检查数组包含的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1509319.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月20日 05:23:34
下一篇 2025年12月20日 05:23:50

相关推荐

  • JavaScript中的代码重构有哪些常见技巧和最佳实践?

    JavaScript代码重构的核心目标是提升代码的可读性、可维护性和可扩展性。通过提取函数将独立逻辑封装,避免重复代码;用常量替代魔法值以增强可配置性;简化条件判断减少嵌套,提高清晰度;利用默认参数和解构赋值优化函数调用;合并重复代码并抽象公共逻辑;改进变量命名使意图明确;采用箭头函数、数组方法和模…

    2025年12月20日
    000
  • JavaScript类型系统深度探索

    JavaScript采用动态弱类型系统,包含七种原始类型(Undefined、Null、Boolean、Number、String、Symbol、BigInt)和一种引用类型Object。 JavaScript 的类型系统看似简单,实则蕴含许多容易被忽视的细节。它采用的是动态、弱类型机制,同时在底层…

    2025年12月20日
    000
  • JavaScript防抖与节流函数实现

    防抖和节流是优化高频事件的两种手段。防抖通过延迟执行,确保事件停止触发后才执行一次回调,适用于搜索输入等场景;节流则保证在指定时间间隔内最多执行一次函数,适合滚动监听等需稳定频率的场景。两者核心区别在于:防抖关注最终状态,节流注重规律执行。根据需求选择可显著提升性能与体验。 在处理高频触发事件时,比…

    2025年12月20日
    000
  • JavaScript类型系统与类型推断机制

    JavaScript是动态类型语言,运行时确定类型并可改变,包含七种基本类型(number、string、boolean、null、undefined、symbol、bigint),对象均属object类型;引擎通过typeof识别类型,但null存在历史bug;运算中会隐式转换类型,如+操作符触发…

    2025年12月20日
    000
  • JavaScript性能监控与分析工具

    浏览器内置工具如Chrome DevTools可分析JS执行耗时、内存泄漏与调用栈;2. Performance API支持代码级性能测量;3. Lighthouse、Sentry和web-vitals实现自动化监控与核心指标采集;4. Webpack Bundle Analyzer、clinic.…

    2025年12月20日
    000
  • JavaScript内存管理与垃圾回收策略

    JavaScript内存管理自动分配并由垃圾回收机制处理,理解该机制可避免内存泄漏、提升性能。内存生命周期包括分配、使用和释放三个阶段,其中释放由引擎自动完成。主要垃圾回收策略有引用计数和标记清除,前者因无法处理循环引用易导致泄漏,后者通过根对象标记可达性有效回收不可达对象。常见泄漏场景包括全局变量…

    2025年12月20日
    000
  • JavaScript打包工具配置优化

    从工具选择到配置优化,提升打包效率需综合施策。1. 选用Vite或Webpack并启用Tree Shaking、splitChunks和资源压缩以减小体积;2. 利用缓存、babel转译限制和并行处理加速构建;3. 通过contenthash命名、代码分割和bundle分析优化输出结构;4. 借助V…

    2025年12月20日
    000
  • JavaScript懒加载实现方案

    答案:懒加载通过延迟加载非首屏资源提升性能。1. Intersection Observer API高效监听元素进入视口,适用于图片懒加载;2. scroll事件兼容旧浏览器,但性能较差;3. dynamic import实现组件级懒加载,配合构建工具分割代码;4. 图片加载完成后再显示,避免布局偏…

    2025年12月20日
    000
  • JavaScript异常处理与调试技巧

    掌握JavaScript异常处理与调试技巧至关重要。使用try-catch-finally捕获同步错误,注意其无法直接处理异步异常;在Promise链末尾添加.catch(),在async函数中用try-catch包裹await调用,并监听unhandledrejection事件兜底;利用Chrom…

    2025年12月20日
    000
  • JavaScript元编程与反射API

    元编程指程序能操作代码本身,JavaScript通过Proxy和Reflect实现。Proxy可拦截对象操作如get、set,用于日志、验证等;Reflect提供统一的函数式对象操作方法,常与Proxy配合使用。两者结合广泛应用于响应式系统(如Vue 3)、调试监控、权限控制等场景,是现代框架核心机…

    2025年12月20日
    000
  • 如何设计一个支持行为驱动开发(BDD)的测试框架?

    答案:设计BDD测试框架需结合自然语言与自动化工具,核心是用Gherkin语法编写Given-When-Then结构的.feature文件,通过Cucumber或Behave解析,集成Selenium等实现Web自动化,配合pytest或TestNG执行测试;步骤定义层应解耦复用,采用页面对象模式,…

    2025年12月20日
    000
  • JavaScript中的代码混淆和压缩有哪些原理和工具?

    代码混淆与压缩通过去除冗余、缩短变量名、加密字符串等手段减小体积并增加逆向难度,常用工具如Terser用于压缩,JavaScript Obfuscator用于混淆,建议生产环境结合使用以平衡性能与安全。 JavaScript的代码混淆和压缩是为了减小文件体积、提升加载速度,同时增加反向工程的难度。虽…

    2025年12月20日
    000
  • JavaScript JWT令牌管理方案

    答案:现代Web应用中JWT管理需兼顾安全与可用,首先登录后将令牌存入localStorage或内存,通过拦截器自动在请求头添加Authorization,结合exp字段判断过期并实现刷新机制,服务端验证签名且避免存储敏感信息,防范XSS与CSRF风险。 在现代Web应用中,JWT(JSON Web…

    2025年12月20日
    000
  • JavaScript Promise异步处理进阶

    Promise通过链式调用实现异步流程控制,每个then返回新Promise,值按规则传递;catch处理前序错误但需末尾兜底;Promise.all等待所有成功,race取最快结果;可封装重试机制提升容错,核心在于状态流转与组合能力。 JavaScript中的Promise不只是解决回调地狱的工具…

    2025年12月20日
    000
  • JavaScript异步编程深度解析与实现

    JavaScript异步编程通过事件循环与任务队列实现非阻塞执行,宏任务(如setTimeout)和微任务(如Promise.then)按序调度,微任务优先执行;Promise解决回调地狱问题,提供链式调用与错误捕获;async/await基于Promise简化语法,提升代码可读性;实际应用中需注意…

    2025年12月20日
    000
  • 如何实现一个基于规则的业务流程引擎?

    答案:基于规则的业务流程引擎通过“条件-动作”规则驱动流程执行,提升灵活性与可维护性。首先定义流程模型,包含节点、流转条件和上下文数据,使用JSON或DSL描述规则;接着构建规则引擎核心,维护规则库并支持动态加载,结合上下文进行规则匹配,采用优先级或首次命中策略;然后管理流程生命周期,记录状态与执行…

    2025年12月20日
    000
  • JavaScript微服务架构设计

    JavaScript%ignore_a_1%架构需基于业务边界解耦,采用Node.js非阻塞I/O提升性能;按DDD和单一职责划分服务,独立部署与数据隔离;通过REST、gRPC或消息队列实现通信;引入API网关与服务发现统一管理入口与寻址;结合日志、追踪、监控保障可观测性,形成完整工程体系。 Ja…

    2025年12月20日
    000
  • JavaScript Express框架深度应用

    Express的核心是中间件机制,通过next()按序传递控制权,可自定义日志、认证等中间件;使用express.Router()实现模块化路由设计,结合控制器分离逻辑;支持EJS等模板引擎进行服务端渲染,并通过app.use(express.static())提供静态资源;生产环境中需集成helm…

    2025年12月20日
    000
  • 使用正则表达式从结构化文本中高效提取姓名信息

    本文旨在提供一个使用正则表达式从特定格式的文本中提取姓名信息的教程。我们将探讨如何利用正则表达式的捕获组和匹配模式,精准识别并分离如“姓名 • • • • • 姓氏”这类结构化数据,并给出详细的javascript代码示例,帮助读者高效处理类似数据提取任务。 在日常的数据处理任务中,我们经常需要从非…

    2025年12月20日
    000
  • 深入理解HTML属性中特殊字符与实体编码的解析差异

    本文深入探讨了html属性中特殊字符(如普通空格)与html实体(如` `和`浏览器解码为对应的字符。理解这一机制对于准确处理和比较html属性值至关重要。 在Web开发中,我们经常需要在HTML元素上设置自定义属性(如data-*属性)来存储数据。当这些属性的值包含特殊字符或HTML实体时,通过J…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信