es6数组includes()用法实例分析


Posted in Javascript onApril 18, 2020

本文实例讲述了es6数组includes()用法。分享给大家供大家参考,具体如下:

Array.prototype.includes方法返回一个布尔值,表示某个数组是否包含给定的值,与字符串的includes方法类似。ES2016引入了该方法。

[1, 2, 3].includes(2) // true
[1, 2, 3].includes(4) // true
[1, 2, NaN].includes(NaN) // true

该方法的第二个参数表示搜索的起始位置,默认为0。如果第二个参数为负数,则表示倒数的位置,如果这时它大于数组长度(比如第二个参数为-4, 但数组长度为3),则会重置为0开始。

[1, 2, 3].includes(3, 3); // false
[1, 2, 3].includes(3, -1); // true

没有该方法之前,我们通常使用数组的indexOf方法,检查是否包含某个值。

if (arr.indexOf(el) !== -1) {
 // ...
}

indexOf方法有两个缺点,一是不够语义化,它的含义是找到参数值的第一个出现位置,所以要去比较是否不等于-1,表达起来不够直观。二是,它内部使用严格相等运算符进行判断,这会导致对NaN的误判。

[NaN].indexOf(NaN) // -1

includes使用的是不一样的判断算法,就没有这个问题。

[NaN].includes(NaN) // true

下面代码用来检查当前环境是否支持该方法,如果不支持,部署一个简易的替代版本。

const contains = (() => Array.prototype.includes 
? (arr, value) => arr.includes(value)
:(arr, value) => arr.some(el => el === value) 
)()

另外,Map和Set数据结构有一个has方法需要注意与includes区分。

-Map结构的has方法,是用来查找键名的,比如Map.prototype.has(key),
WeakMap.prototype.has(key), Reflect.has(target, propertyKey)

-Set结构的has方法,是用来查找值的,比如Set.prototype.has(value),
WeakSet.prototype.has(value)

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

更多关于JavaScript相关内容可查看本站专题:《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
网页的标准,IMG不支持onload标签怎么办
Jun 29 Javascript
javascript Demo模态窗口
Dec 06 Javascript
js模仿hover的具体实现代码
Dec 30 Javascript
javascript动态获取登录时间和在线时长
Feb 25 Javascript
noty ? jQuery通知插件全面解析
May 18 Javascript
jQuery Mobile漏洞会有跨站脚本攻击风险
Feb 12 Javascript
vue-hook-form使用详解
Apr 07 Javascript
vue 设置proxyTable参数进行代理跨域
Apr 09 Javascript
完美解决linux下node.js全局模块找不到的情况
May 16 Javascript
jQuery仿移动端支付宝键盘的实现代码
Aug 15 jQuery
TypeScript的安装、使用、自动编译的实现
Apr 10 Javascript
基于 Vue 的 Electron 项目搭建过程图文详解
Jul 22 Javascript
es6数组的flat(),flatMap()函数用法实例分析
Apr 18 #Javascript
es6函数中的作用域实例分析
Apr 18 #Javascript
es6函数之rest参数用法实例分析
Apr 18 #Javascript
vue实现短信验证码输入框
Apr 17 #Javascript
JS监听组合按键思路及实现过程
Apr 17 #Javascript
javascript canvas检测小球碰撞
Apr 17 #Javascript
Vue实现浏览器打印功能的代码
Apr 17 #Javascript
You might like
如何批量替换相对地址为绝对地址(利用bat批处理实现)
2013/05/27 PHP
PHP对接微信公众平台消息接口开发流程教程
2014/03/25 PHP
php实现redis数据库指定库号迁移的方法
2015/01/14 PHP
PHP中的表达式简述
2016/05/29 PHP
Joomla框架实现字符串截取的方法示例
2017/07/18 PHP
ASP.NET jQuery 实例10 动态修改hyperlink的URL值
2012/02/03 Javascript
jQuery实现的多选框多级联动插件
2014/05/02 Javascript
jQuery判断复选框是否勾选的原理及示例
2014/05/21 Javascript
JS控制网页动态生成任意行列数表格的方法
2015/03/09 Javascript
JavaScript输出当前时间Unix时间戳的方法
2015/04/06 Javascript
jquery实现定时自动轮播特效
2015/12/10 Javascript
AngularJS 模块详解及简单实例
2016/07/28 Javascript
浅谈JS继承_借用构造函数 & 组合式继承
2016/08/16 Javascript
微信js-sdk界面操作接口用法示例
2016/10/12 Javascript
5分钟打造简易高效的webpack常用配置
2017/07/04 Javascript
jQuery中过滤器的基本用法示例
2017/10/11 jQuery
详解node child_process模块学习笔记
2018/01/24 Javascript
详解从Vue-router到html5的pushState
2018/07/21 Javascript
vue实现动态表格提交参数动态生成控件的操作
2020/11/09 Javascript
[55:54]FNATIC vs EG 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/16 DOTA
Python模糊查询本地文件夹去除文件后缀的实例(7行代码)
2017/11/09 Python
很酷的python表白工具 你喜欢我吗
2019/04/11 Python
jupyter notebook 中输出pyecharts图实例
2020/04/23 Python
Python秒算24点实现及原理详解
2019/07/29 Python
python基于TCP实现的文件下载器功能案例
2019/12/10 Python
Python 窗体(tkinter)下拉列表框(Combobox)实例
2020/03/04 Python
阿联酋航空官方网站:Emirates
2017/10/17 全球购物
百思买加拿大:Best Buy Canada
2018/03/20 全球购物
大学生就业自我推荐信
2014/05/10 职场文书
学习演讲稿范文
2014/05/10 职场文书
代办委托书怎么写
2014/08/01 职场文书
员工保密协议书
2014/09/27 职场文书
体检通知范文
2015/04/21 职场文书
送给自己的励志语句:要安静的优秀,悄无声息的坚强
2019/11/26 职场文书
总结python多进程multiprocessing的相关知识
2021/06/29 Python
Python加密技术之RSA加密解密的实现
2022/04/08 Python