关于ES5的indexof()和ES7的includes()的区别

时间:2021-08-05 04:52:06

早es5的时候就有了查找数组中是否包含某个值的API  indexOf(); 使用方法很简单,比如有个数组是:

var arr=[2,3,4,"php"]

如果我们想知道数组中有没有"php"这一项,只需要 indexOf("php")

关于ES5的indexof()和ES7的includes()的区别

如果存在会返回查找值的位置,找不到会返回-1;但是这有个问题就是,如果查找的值碰巧是NaN呢:

关于ES5的indexof()和ES7的includes()的区别

就会返回-1,这不是我们想要的结果,再来看看includes()方法可以做到吗:

关于ES5的indexof()和ES7的includes()的区别

includes()方法正确的判断了NaN是否存在,而indexOf()不行。

比较:

1,使用方法基本一样

2,初衷都是查看数组是否包含某个值

3,indexOf没有includes语义化更强

4,includes更加完善