首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

js 不重复数组

在JavaScript中,要创建一个不包含重复元素的数组,可以使用以下几种方法:

1. 使用 Set 对象

Set 是ES6引入的一种新的数据结构,它类似于数组,但是成员的值都是唯一的,没有重复的值。可以利用这个特性来去除数组中的重复元素。

代码语言:txt
复制
const array = [1, 2, 3, 2, 4, 1];
const uniqueArray = [...new Set(array)];
console.log(uniqueArray); // 输出: [1, 2, 3, 4]

2. 使用 filter 方法

可以通过数组的 filter 方法结合 indexOf 来过滤掉重复的元素。

代码语言:txt
复制
const array = [1, 2, 3, 2, 4, 1];
const uniqueArray = array.filter((item, index) => array.indexOf(item) === index);
console.log(uniqueArray); // 输出: [1, 2, 3, 4]

3. 使用 reduce 方法

reduce 方法可以用来累积数组中的值,通过检查累积器中是否已经有了当前元素,来决定是否将其添加到结果数组中。

代码语言:txt
复制
const array = [1, 2, 3, 2, 4, 1];
const uniqueArray = array.reduce((accumulator, current) => {
  if (!accumulator.includes(current)) {
    accumulator.push(current);
  }
  return accumulator;
}, []);
console.log(uniqueArray); // 输出: [1, 2, 3, 4]

4. 使用对象属性

可以利用对象的属性来检查元素是否已经出现过,因为对象的属性名是唯一的。

代码语言:txt
复制
const array = [1, 2, 3, 2, 4, 1];
const uniqueArray = [];
const seen = {};

for (let item of array) {
  if (!seen[item]) {
    uniqueArray.push(item);
    seen[item] = true;
  }
}

console.log(uniqueArray); // 输出: [1, 2, 3, 4]

优势

  • Set 方法简洁且性能较好,是去重数组的首选方法。
  • filterreduce 方法提供了更多的灵活性,可以在去重的同时进行其他操作。
  • 使用对象属性的方法在某些情况下性能也很好,尤其是当数组中的元素是基本类型时。

应用场景

这些方法可以应用于任何需要去除数组中重复元素的场景,例如:

  • 数据清洗:在处理用户输入或外部数据时,去除重复项。
  • 数据统计:在进行数据分析时,确保每个数据点只被计算一次。
  • 用户界面:在展示列表或表格数据时,避免重复显示相同的内容。

注意事项

  • 当数组中的元素是对象时,上述方法可能无法正确去重,因为对象在JavaScript中是通过引用比较的。在这种情况下,需要自定义去重逻辑,比如通过JSON.stringify方法或者自定义的深度比较函数。
代码语言:txt
复制
const array = [{ id: 1 }, { id: 2 }, { id: 1 }];
const uniqueArray = Array.from(new Map(array.map(item => [item.id, item])).values());
console.log(uniqueArray); // 输出: [{ id: 1 }, { id: 2 }]

在这个例子中,我们使用了 Map 对象来确保对象的唯一性,通过对象的 id 属性来判断是否重复。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

构建不重复特殊数组

Python3 初学实践案例(13)构建不重复特殊数组 前言 今天遇到一个问题,很难用一句话描述。所以,我用一段文字来描述这个问题。...数组的每一段为两个随机数字,加上 - 构成。 这两个数字不能重复,比如: 9-9 这样的就不行。 数组内不能重复的出现如 ['1-2', '1-2'] 这样的重复字符串。...生成 x*2 的随机字符串,放进 res 这个数组 for i in range(1,x*2): # 从 dic 字典里随机取两个不重复的数字 # 排序,然后用...返回结果 return res # 主函数,打印一下 if __name__ == "__main__": print(randomList(10)) 关键点 在一个序列中取出 n 个不重复的内容...数组排序 sorted() 数字或者字符串都能排序 数组去重 list(set(arr)) 原理非常简单,set 里面是不能有重复内容的。所以先转成 set 再转成 list 即可实现去重。

83450

原生JS | 随机抽取不重复的数组元素 —— 有没有更好的方法?

HTML5学堂-码匠:从数组中随机抽取不重复的元素,构成新数组,拥有多种方法,来看看你用的方法性能如何? 效果的功能需求 从一个数组当中,随机抽取数个元素,构成新数组,要求这些元素不能重复。...(即随机获取不重复的数组元素) 相关说明:在此处依照“构思难度”和“性能”两方面出发,提供了四种不同的实现方法。...基本实现思路 该方法的基本原理是,在抽取一个元素之后,将该元素与数组末端的最后一个元素交换,然后将数组最后一个元素扔掉。...随着比较的进行,每次被抽取的元素都被交换到了数组末端,再被扔掉,数组长度也越来越短。...也就是说,我们只要保证当前元素被末尾元素替代,并不断减小随机数范围,“数组长度”和“数组末尾的元素值”是可以忽略的。

9.4K50
  • js实现两个数组对象,重复的属性覆盖,不重复的添加

    当使用ES5语法时,你可以使用for循环和hasOwnProperty方法来实现两个数组对象的合并,覆盖重复的属性,并添加不重复的属性。...以下是一个示例代码:function mergeArrays(arr1, arr2) { var merged = []; var propMap = {}; // 遍历第一个数组,将属性添加到...然后,通过遍历第一个数组 arr1,将属性添加到 merged 数组中,并在 propMap 对象中以属性的键值作为键,属性对象作为值进行存储。...接下来,遍历第二个数组 arr2,对于每个属性,检查它是否已存在于 propMap 中。如果存在,说明属性是重复的,则找到它在 merged 数组中的位置,并用第二个数组中的属性对象覆盖它。...如果不存在,说明属性是不重复的,直接将属性添加到 merged 数组中。最后,返回合并后的数组 merged。这样就实现了两个数组对象的合并,重复属性被覆盖,不重复属性被添加。

    47510

    js数组浅拷贝_js数组深度复制

    数组的浅拷贝, 可用concat、slice返回一个新数组的特性来实现拷贝 var arr = ['old', 1, true, null, undefined]; var new_arr = arr.concat...source.a.b = 10; console.log(source); // { a: { b: 10 } }; console.log(target); // { a: { b: 10 } }; 但是如果数组嵌套了对象或者数组的话用...== 'object') return; // 根据obj的类型判断是新建一个数组还是一个对象 var newObj = Array.isArray(obj) ?...,就会拷贝一份,互不影响,而如果是对象或者数组,就会只拷贝对象和数组的引用,这样我们无论在新旧数组进行了修改,两者都会发生变化。...数组的深拷贝 方法一:JSON.stringify()不仅可拷贝数组还能拷贝对象(但不能拷贝函数,也不能解决循环引用问题) var arr = ['old', 1, true, ['old1', 'old2

    13.2K50

    html js 数组添加,js数组添加数据

    本文介绍js数组添加数据的三种方法:1、结尾添加push()方法;2、头部添加unshift() 方法;3、向/从数组指定位置添加/删除项目,然后返回被删除的项目splice() 方法。...要添加到数组的第一个元素。 b:可选。要添加到数组的第二个元素。 c:可选。可添加多个元素。 3、返回值 把指定的值添加到数组后的新长度。...向数组添加的第一个元素。 b:可选。向数组添加的第二个元素。 c:可选。可添加若干个元素。 3、返回值 arrayObject 的新长度。...整数,规定添加/删除项目的位置,使用负数可从数组结尾处规定位置。 b:必需。要删除的项目数量。如果设置为 0,则不会删除项目。 item1,…..,itemX:可选。向数组添加的新项目。...tony alert(arr.splice(1,0,’tony’)) //返回值为空 alert(arr) // smile,tony,2,3,marie 以上就是js数组添加数据的四种方法,大家可以根据在不同的位置添加数据选择不同的方法哦

    26.2K10

    js数组笔记

    一、定义 数组(array)是按次序排列的一组值。每个值的位置都有编号(从0开始)。整个数组用方括号表示,数组的值用','分割;数组的数据可以是任何类型。...原数组会会变化,截取的部分自动为一个数组返回。...,对数组的每个值执行函数操作,并把结果返回新数组 1)原理:遍历数组,对函数的每个值执行回调函数,返回值组成一个新数组。...原数组不变 2)函数参数: element:数组当前项的值 index:数组当前项的索引(可选) array:数组对象本身(可选) thisArg:执行 callback 函数时使用的this 值(可选...,对数组每一个元素执行callback函数,并将满足条件的值返回新数组 1)原理:遍历数组,对数组每一个元素执行callback函数,并将满足条件的值返回新数组。

    11.8K30

    JS之数组

    大家好,我是萧寒,今日分享的是js中的数组。 JS之数组 为什么要学数组? 我们先来思考一个问题,如果我们想储存班级中47个学生的期末成绩,那么该如何存储呢?...什么是数组呢? 数组是一组数据的集合,其中的每个数据被称为元素,在数组中可以存放任意类型的元素,数组是一种将一组数据存储在单个变量名下的优雅方式。...我们能使用手机,电脑正是因为它们存在我们才有机会去使用,数组也是一样,要使用必须自己创建一个数组,在JS中创建数组有一下两种方式 利用new创建数组 利用数组字面量创建数组 利用new创建数组...在JS当中我们压根就不用关心这个问题,因为js的数组中可以存放任意类型的数据,例如字符串,数字,布尔值。 var arr=['小白',121,true,29.9]; //这就很舒服。...法一:修改length长度新增数组元素 可以通过修改length长度来实现数组扩容 length属性即可读 法二:通过修改数组索引新增数组元素 可以通过修改数组索引的方式追加数组元素 不能直接给数组名赋值

    19320

    js中map遍历数组对象_js遍历数组

    forEach()和map()都是遍历数组的方法,用法类似,但是还是有很大区别: 相同点:       1.都是循环遍历数组中的每一项;       2.在遍历中执行匿名函数都可以接收三个参数,分别为...不同点:       map():       根据遍历执行的匿名函数,对于原数组中的每个值产生一个对应的值,并返回一个新的数组,存在一个映射关系,并且不会改变原数组,不会对空数组进行检测。...arr.forEach(function(i,index,arr){ sum += i; console.log("sum的值为:",sum); }) //执行5次,最终结果 10 ** js...中 map 遍历数组 ** map 方法会迭代数组中的每一个元素,并根据回调函数来处理每一个元素,最后返回一个新数组。...注意,这个方法不会改变原始数组。 在我们的例子中,回调函数只有一个参数,即数组中元素的值 (val 参数) ,但其实,你的回调函数也可以支持多个参数,譬如:元素的索引index、原始数组arr。

    19.6K30

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券