一、 场景🌟
今天在解读Element中popper.js的源码时,发现了这样一句代码
if (
['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow')) !== -1 ||
['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow-x')) !== -1 ||
['scroll', 'auto'].indexOf(getStyleComputedProperty(parent, 'overflow-y')) !== -1
) {
return parent;
}
复制代码
具体在该判断语句中的作用为判断parent这个元素的overflow样式属性是否为'scroll'或者'auto',自己也试着打了一小段。
let arr = ['string','number','object'];
arr.indexOf('number');
//1
复制代码
确实是自己才疏学浅了😳,之前对于indexOf的用法一直停留在用来检索字符串中是否包含另一个字符串(w3school关于indexOf的描述),不过太过简略了,主要还是自己平时懒很少去复习文档,其实很多文档已经添加了关于indexOf在数组上的拓展案例。
那么好玩的来了,既然indexOf返回的是字符串第一次出现的位置,那么数组去重是不是可以这样写呢。
let arr1 = ['string','number','object','string'];
let arr2 = [];
arr1.forEach(item => {
if(arr2.indexOf(item) === -1){
arr2.push(item);
}
})
[...arr2];
//['string','number','object'];
复制代码
二、总结👻
算是对自己疏漏知识点的一个补充吧,其实平常很少在数组中使用这类的方法,就比如数组去重,es6有更快的解决方法(只是代码简洁了,没有考虑代码是解读以及后续转换为数组在性能方面的问题)。
let arr1 = ['string','number','object','string'];
let arr2 = new Set(arr1);
[...arr2];
//['string','number','object'];
复制代码
好了,我继续看代码去了,886。
关于找一找教程网
本站文章仅代表作者观点,不代表本站立场,所有文章非营利性免费分享。
本站提供了软件编程、网站开发技术、服务器运维、人工智能等等IT技术文章,希望广大程序员努力学习,让我们用科技改变世界。
[【小知识点??】indexOf在数组中竟能这样使用???!]http://www.zyiz.net/tech/detail-141688.html