js实用技巧之去除数组或者对象里重复选项
作者:huyt-web
这篇文章主要给大家介绍了关于js实用技巧之去除数组或者对象里重复选项的相关资料,JavaScript数组有很多内置方法,可以操作和处理数据,文中通过代码示例介绍的非常详细,需要的朋友可以参考下
前言
在 JavaScript 中,数组去重,对象去重,可以使用多种方法来去除数组或对象中的重复项。以下是其中的一些方法:
去除数组中的重复项
方法一:使用 Set
使用 Set 是去除数组中重复项的最简单和最快的方法。Set 对象是一组不重复的值的集合,可以接受一个数组(或者具有可迭代属性的其他对象)作为参数,并返回一个包含不重复元素的新数组。例如:
javascriptCopy code const arr = [1, 2, 3, 3, 4, 5, 5]; const uniqueArr = [...new Set(arr)]; console.log(uniqueArr); // [1, 2, 3, 4, 5]
方法二:使用 filter 和 indexOf
使用 filter 和 indexOf 方法可以从数组中删除重复项。例如:
javascriptCopy code const arr = [1, 2, 3, 3, 4, 5, 5]; const uniqueArr = arr.filter((item, index) => { return arr.indexOf(item) === index; }); console.log(uniqueArr); // [1, 2, 3, 4, 5]
方法三:使用 reduce 和 includes
使用 reduce 和 includes 方法可以从数组中删除重复项。例如:
javascriptCopy code const arr = [1, 2, 3, 3, 4, 5, 5]; const uniqueArr = arr.reduce((prev, cur) => { if (!prev.includes(cur)) { prev.push(cur); } return prev; }, []); console.log(uniqueArr); // [1, 2, 3, 4, 5]
去除对象中的重复项
方法一:使用 for…in 和 hasOwnProperty
使用 for…in 循环遍历对象的属性,并使用 hasOwnProperty 方法检查属性是否是对象自身的属性。例如:
javascriptCopy code const obj = { a: 1, b: 2, c: 3, d: 3, e: 4, f: 4 }; const uniqueObj = {}; for (const key in obj) { if (obj.hasOwnProperty(key)) { uniqueObj[obj[key]] = key; } } console.log(uniqueObj); // { '1': 'a', '2': 'b', '3': 'c', '4': 'e' }
方法二:使用 Object.keys 和 reduce
使用 Object.keys 方法获取对象的所有属性,然后使用 reduce 方法来去除重复项。例如:
javascriptCopy code const obj = { a: 1, b: 2, c: 3, d: 3, e: 4, f: 4 }; const uniqueObj = Object.keys(obj).reduce((prev, key) => { const value = obj[key]; if (!prev.hasOwnProperty(value)) { prev[value] = key; } return prev; }, {}); console.log(uniqueObj); // { '1': 'a', '2': 'b', '3': 'c', '4': 'e' }
以上是去除数组或对象中的重复项的几种方法。选择哪种方法取决于个人喜好和具体情况。
总结
到此这篇关于js实用技巧之去除数组或者对象里重复选项的文章就介绍到这了,更多相关js去除数组对象重复选项内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!