javaScript 前端面试题 30天学习计划 ----数组去重(第六天)

javaScript 前端面试题 30天学习计划 ----(第六天)

日常任务

  1. 前端面试题练习
  • 学习习题所提知识点(概念、内容、用法)
  • 掌握习题答案
  • 用自己的理解解答习题
  1. 复习前一天所学知识
  • 代码操作
  • 掌握习题答案
  • 记忆知识点(概念、内容、用法)

数组去重? JavaScript 高性能数组去重

  1. 双重 for 循环: 外层循环遍历元素,内层循环检查是否重复,当有重复值的时候,使用 splice()删除。
var a = [1, 1, 'true', 'true', true, true, 15, 15, 
false, false, undefined, undefined, null, null, 0, 0, 'a','a', {}, {}];

for (var i = 0; i < a.length; i++) {
	for (var j = i + 1; j < a.length; j++) {
		if (a[i] == a[j]) {
			a.splice(j, 1);
		}
	}
}

//或

for (let i = 0; i < a.length; i++) {
    if(i!=0 && a[i] == a[i-1]){
        a.splice(i, 1);
    }
}
console.log(a);
// [1, "true", true, 15, false, undefined, null, 0, "a", {…}, {…}]
  1. Array.filter() + indexOf: filter检测数值元素,并返回符合条件所有元素的数组,indexOf 来排除重复项。
var a = [1, 1, 'true', 'true', true, true, 15, 15, 
false, false, undefined, undefined, null, null, 0, 0, 'a','a', {}, {}];

var b = a.filter(function(item,index){
	//判断元素在数组中第一次出现的位置是否与当前索引一致
	return a.indexOf(item) === index;
})
console.log(b);
// [1, "true", true, 15, false, undefined, null, 0, "a", {…}, {…}]
  1. for…of + includes(): for…of遍历数组,新建一个空数组,includes()方法判断元素是否已存在。
var a = [1, 1, 'true', 'true', true, true, 15, 15, 
false, false, undefined, undefined, null, null, 0, 0, 'a','a', {}, {}];

var b = [];
for(let key of a){
	if(!b.includes(key)){
		b.push(key)
	}
}
console.log(b);
// [1, "true", true, 15, false, undefined, null, 0, "a", {…}, {…}]
  1. Array.sort(): 使用 sort() 将数组进行排序,然后比较相邻元素是否相等,从而排除重复项。
var a = [1, 1, 'true', 'true', true, true, 15, 15, 
false, false, undefined, undefined, null, null, 0, 0, 'a','a', {}, {}];

a.sort();
var b = [a[0]];
for(let i=1;i<a.length;i++){
	if(a[i] != a[i-1]){
		b.push(a[i]);
	}
}
console.log(b);
//!= [0, 1, 15, {…}, {…}, "a", false, null, true, "true", undefined]
//!== [0, 1, 15, {…}, {…}, "a", false, null, true, "true", undefined]
  1. new Set(): ES6 新增 Set 这一数据结构,类似于数组, Set 的成员具有唯一性。
var a = [1, 1, 'true', 'true', true, true, 15, 15, 
false, false, undefined, undefined, null, null, 0, 0, 'a','a', {}, {}];

var b = Array.from(new Set([...a]));
console.log(b);
//[1, "true", true, 15, false, undefined, null, 0, "a", {…}, {…}]
  1. for…of + Object: 利用对象的属性不会重复这一特性,校验数组元素是否重复。
var a = [1, 1, 'true', 'true', true, true, 15, 15, 
false, false, undefined, undefined, null, null, 0, 0, 'a','a', {}, {}];

var b = [];
var obj = {};
for(let key of a){
	if(!obj[key]){
		b.push(key);
		obj[key] = 1;
	}
}
console.log(b);
// [1, "true", 15, false, undefined, null, 0, "a", {…}]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

呆瓜の无戒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值