数组去重
阿里面试官,喜欢问这个问题。
let array=[1, "1", 2, 1, 1, 3];
//拓展运算符(...)内部使用for...of循环
[...new Set(array)];//[1, "1", 2, 3]
//利用Array.from将Set结构转换成数组
Array.from(new Set(array));//[1, "1", 2, 3]
传统的方法,循环遍历:排序sort()后前一下与后一个比较==;在数组中用indexOf判断,利用includes,利用filter;这些方法感觉都过时了,还是用ES6中利用Set去重比较牛。
取数组中的最大值和最小值
Math.max方法可以求出给定参数中最大的数。
Math.max('1','2','3.1','3.2');//3.2
Math.min(1,0,-1);//-1
但如果是数组,就不能这样调用了。此时就用到了apply方法。
Function.apply()是JS的一个OOP特性,一般用来模拟继承和扩展this的用途。
所有函数都有apply(作用域链,参数)这个方法,当作用域链为null时,
默认为上文,这个函数的“参数”,接收一个数组。
let arr = ['1','2','3.1','3.2',0,-1];
//用apply方法
Math.max.apply(null, arr);//3.2
Math.min.apply(Math, arr);//-1
//用拓展运算符
Math.max(...arr);//3.2
Math.min(...arr);//-1
另外一种undefined
let data = void 0; // undefined
void 运算符 对给定的表达式进行求值,然后返回 undefined。
那为什么要用void 0,不直接undefined呢? undefined
在javascript中不是保留字。因此在IE5.5~8中我们可以将其当作变量那样对其赋值(IE9+及其他现代浏览器中赋值给undefined将无效)。采用void方式获取undefined
更准确。
短路表达式,弃用if-else
用 || 和 &&来简化if-else 。有时候用 !! 操作符也能简化if-else模式。例如这样:
let a = b || 1;//b为真,a=b;b为假,a=1;
let c = b && 1;//b为真,c=1;b为假,c=b;
// 使用!!符号
let isValid = !!(value && value !== 'error');
“!”是取反操作,两个“!”自然是负负得正了。比较常用的是||。
数组中查找某一条includes
![237412f8a3caedead555cb2c0233d586.png](https://i-blog.csdnimg.cn/blog_migrate/18de4c2ca0d67ceca592ba9cd146bc72.jpeg)