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 相关文章推荐
在html页面上拖放移动标签
Jan 08 Javascript
JavaScript 判断指定字符串是否为有效数字
May 11 Javascript
来自国外的页面JavaScript文件优化
Dec 08 Javascript
javascript针对DOM的应用分析(四)
Apr 15 Javascript
Angular中实现树形结构视图实例代码
May 05 Javascript
浅谈 Vue v-model指令的实现原理
Jun 08 Javascript
微信小程序 检查接口状态实例详解
Jun 23 Javascript
解析Vue.js中的组件
Feb 02 Javascript
解决vue-cli创建项目的loader问题
Mar 13 Javascript
vue 微信授权登录解决方案
Apr 10 Javascript
vue中的循环对象属性和属性值用法
Sep 04 Javascript
Vue实现简单的留言板
Oct 23 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
关于php操作mysql执行数据库查询的一些常用操作汇总
2013/06/24 PHP
php返回json数据函数实例
2014/10/09 PHP
php判断是否为ajax请求的方法
2016/11/29 PHP
Jquery 基础学习笔记
2009/05/29 Javascript
Javascript图像处理—虚拟边缘介绍及使用方法
2012/12/27 Javascript
本地图片预览(支持IE6/IE7/IE8/Firefox3)经验总结
2013/03/25 Javascript
node.js中的events.emitter.removeListener方法使用说明
2014/12/10 Javascript
JavaScript获取网页中第一个图片id的方法
2015/04/03 Javascript
JavaScript知识点总结之如何提高性能
2016/01/15 Javascript
Jquery attr()方法 属性赋值和属性获取详解
2016/04/15 Javascript
浅谈vue-lazyload实现的详细过程
2017/08/22 Javascript
vue中使用echarts制作圆环图的实例代码
2018/07/27 Javascript
angularjs 动态从后台获取下拉框的值方法
2018/08/13 Javascript
在微信小程序中使用图表的方法示例
2019/04/25 Javascript
vue-cli3项目展示本地Markdown文件的方法
2019/06/07 Javascript
Vue+Typescript中在Vue上挂载axios使用时报错问题
2019/08/07 Javascript
Javascript执行流程细节原理解析
2020/05/14 Javascript
React实现阿里云OSS上传文件的示例
2020/08/10 Javascript
Python操作列表之List.insert()方法的使用
2015/05/20 Python
Python通过Pygame绘制移动的矩形实例代码
2018/01/03 Python
Python实现抢购IPhone手机
2018/02/07 Python
详解python深浅拷贝区别
2019/06/24 Python
Python PIL读取的图像发生自动旋转的实现方法
2019/07/05 Python
基于python使用tibco ems代码实例
2019/12/20 Python
Python读入mnist二进制图像文件并显示实例
2020/04/24 Python
基于python计算并显示日间、星期客流高峰
2020/05/07 Python
美国奢侈品购物平台:Orchard Mile
2018/05/02 全球购物
施华洛世奇中国官网:SWAROVSKI中国
2020/06/16 全球购物
语文教研活动总结
2014/07/02 职场文书
2014年街道办事处工作总结
2014/12/11 职场文书
vue+springboot实现登录验证码
2021/05/27 Vue.js
javascript canvas实现雨滴效果
2021/06/09 Javascript
python scrapy简单模拟登录的代码分析
2021/07/21 Python
MySQL插入数据与查询数据
2022/03/25 MySQL
Python编写冷笑话生成器
2022/04/20 Python
mysql查看表结构的三种方法总结
2022/07/07 MySQL