摘要:基本操作數(shù)組去重數(shù)組去重的方法臨時數(shù)組保存其實這里面還沒考慮到數(shù)組里面嵌套數(shù)組對象的情況把去重后的結(jié)果放在一個臨時數(shù)組中對原來數(shù)組的元素與臨時數(shù)組元素比較臨時數(shù)組中不存在這個元素的放入臨時數(shù)組。
js基本操作-數(shù)組去重 數(shù)組去重的方法 1. 臨時數(shù)組保存(其實這里面還沒考慮到數(shù)組里面嵌套數(shù)組/對象的情況)
把去重后的結(jié)果放在一個臨時數(shù)組中, 對原來數(shù)組的元素與臨時數(shù)組元素比較, 臨時數(shù)組中不存在這個元素的, 放入臨時數(shù)組。
function unique (arr) { if (!Array.isArray(arr)) return arr; var result = []; arr.map(function (item) { if (result.indexOf(item) == -1) { result.push(item); } }) return result; }2. 利用對象去重(當數(shù)組的鍵為 11, "11"時, 會保留第一個出現(xiàn)的值)
創(chuàng)建一個新的數(shù)組存放結(jié)果, 和一個空的對象。for循環(huán)時, 每次取出一個元素與對象進行對比, 如果這個元素不重復, 則把它存放到結(jié)果數(shù)組中, 同時把這個元素的內(nèi)容作為一個對象的屬性, 并賦值, 存入對象中。
function unique (arr) { if (!Array.isArray(arr)) return arr; var result = []; var obj = {} arr.map(function (item) { if (!obj[item]) { result.push(item); obj[item] = 1 }; }) return result; }3. 先排序, 后去重
先把數(shù)組排序, 然后比較相鄰的兩個值。排序的時候用原生的 sort 方法, JS引擎內(nèi)部使用的是快速排序。
function unique(arr) { if (!Array.isArray(arr)) return arr; if (arr.length < 2) return arr; arr.sort(); // sort在元數(shù)組進行排序, 不生成副本 var result = [arr[0]] arr.map(function (item, index, arr) { if (index > 0) { if (item !== arr[index - 1]) { result.push(item); } } }) return result; } var arr = [99, 88, 22, 22, 44, 88, 99, "99"] console.log(unique(arr));4. 利用 ES6 的 Set 對象 和 Array.from 方法
Set對象: 它是ES6新增的有序列表集合, 不會包含重復項。
Array.from()方法: 將一個類數(shù)組或可遍歷對象轉(zhuǎn)換成真正的數(shù)組。
function unique (arr) { if (!Array.isArray(arr)) return arr; if (arr.length < 2) return arr; return Array.from(new Set(arr)) } var arr = [99, 88, 22, 22, 44, 88, 99, "99"] console.log(unique(arr));5.利用 filter 和 Map 對象
function unique(arr) { if (!Array.isArray(arr)) return arr; if (arr.length < 2) return arr; return arr.filter(function(item, index, arr) { if (arr.indexOf(item) === index) { return true; } }); } var arr = [99, 88, 22, 22, 44, 88, 99, "99"] console.log(unique(arr));
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/81872.html
摘要:基本操作數(shù)組去重寫在前面數(shù)組去重經(jīng)常出現(xiàn)在前端招聘的筆試題里,比如有數(shù)組,請用實現(xiàn)去重函數(shù),使得返回作為筆試題,考點有二正確?;窘榻B文章主要是對數(shù)組去重的常用方法進行介紹。 js基本操作-數(shù)組去重 寫在前面 JavaScript 數(shù)組去重經(jīng)常出現(xiàn)在前端招聘的筆試題里,比如: 有數(shù)組 var arr = [a, b, c, 1, 0, c, 1, , 1, 0],請用 JavaScr...
摘要:數(shù)組去重看了網(wǎng)上很多數(shù)組去重方法,用的比較常見的大概就幾種,今天想自己來做一個總結(jié)。還有就是方法返回的數(shù)組也是排序后的數(shù)組,某些情況下可能不符合要求。 JS數(shù)組去重 看了網(wǎng)上很多數(shù)組去重方法,用的比較常見的大概就幾種,今天想自己來做一個總結(jié)。部分內(nèi)容參考該博客 1 . 在原數(shù)組上操作(基本方法) 思路:利用循環(huán)嵌套,判斷數(shù)組中每個元素與其后面的元素是否相等,如果相等,就使用spli...
最近lz一周排了9個面試,面試經(jīng)常被問到一些數(shù)組的問題,比如說es6里面一些數(shù)組去重、合并數(shù)組,之前壓根就沒了解過,后來才知道考的都是es6的知識,今天好好挖掘一下,發(fā)現(xiàn)一個神奇的點點三姐妹 我們來看看經(jīng)常使用的方法 1、數(shù)組去重 之前的想法可能要遍歷數(shù)組去重,但是現(xiàn)在又es6的騷操作 var a = [1,1,2,3] Array.from(new Set()) // 利用es6...
摘要:實現(xiàn)數(shù)組更多的高階函數(shù)吾輩的博客原文場景雖說人人平等,但有些人更加平等。若是有一篇適合萌新閱讀的自己實現(xiàn)數(shù)組更多操作的文章,情況或許會發(fā)生一些變化。類似于的初始值,但它是一個函數(shù),避免初始值在所有分組中進行累加。 JavaScript 實現(xiàn)數(shù)組更多的高階函數(shù) 吾輩的博客原文: https://blog.rxliuli.com/p/fc... 場景 雖說人人平等,但有些人更加平等。 為...
數(shù)組去重的方式有很多種,現(xiàn)總結(jié)一些備以后查漏補缺來用。 對基本數(shù)組類型去重: (1)set 和 array.from()實現(xiàn) var str, strs = [a, b, c, er, d, er, a, b, c]; function removeRepeat(arr) { return Array.from(new Set(arr)) } console.log(remove...
閱讀 1025·2021-10-27 14:15
閱讀 2781·2021-10-25 09:45
閱讀 1945·2021-09-02 09:45
閱讀 3372·2019-08-30 15:55
閱讀 1809·2019-08-29 16:05
閱讀 3205·2019-08-28 18:13
閱讀 3120·2019-08-26 13:58
閱讀 457·2019-08-26 12:01