JavaScript實(shí)現(xiàn)數(shù)組去重的7種方法
前言
去重是開發(fā)中經(jīng)常會碰到的一個熱點(diǎn)問題,不過目前項(xiàng)目中碰到的情況都是后臺接口使用SQL去重,簡單高效,基本不會讓前端處理去重。
那么前端處理去重會出現(xiàn)什么情況呢?假如每頁顯示10條不同的數(shù)據(jù),如果數(shù)據(jù)重復(fù)比較嚴(yán)重,那么要顯示10條數(shù)據(jù),可能需要發(fā)送多個http請求才能夠篩選出10條不同的數(shù)據(jù),而如果在后臺就去重了的話,只需一次http請求就能夠獲取到10條不同的數(shù)據(jù)。
當(dāng)然,這并不是說前端去重就沒有必要了,依然需要會熟練使用。本文主要介紹幾種常見的數(shù)組去重的方法。
方法實(shí)現(xiàn)
雙循環(huán)去重
雙重for(或while)循環(huán)是比較笨拙的方法,它實(shí)現(xiàn)的原理很簡單:先定義一個包含原始數(shù)組第一個元素的數(shù)組,然后遍歷原始數(shù)組,將原始數(shù)組中的每個元素與新數(shù)組中的每個元素進(jìn)行比對,如果不重復(fù)則添加到新數(shù)組中,最后返回新數(shù)組;因?yàn)樗臅r(shí)間復(fù)雜度是O(n^2),如果數(shù)組長度很大,那么將會非常耗費(fèi)內(nèi)存
function unique(arr) { if (!Array.isArray(arr)) { console.log('type error!') return } let res = [arr[0]] for (let i = 1; i < arr.length; i++) { let flag = true for (let j = 0; j < res.length; j++) { if (arr[i] === res[j]) { flag = false; break } } if (flag) { res.push(arr[i]) } } return res }
indexOf方法去重1
數(shù)組的indexOf()方法可返回某個指定的元素在數(shù)組中首次出現(xiàn)的位置。該方法首先定義一個空數(shù)組res,然后調(diào)用indexOf方法對原來的數(shù)組進(jìn)行遍歷判斷,如果元素不在res中,則將其push進(jìn)res中,最后將res返回即可獲得去重的數(shù)組
function unique(arr) { if (!Array.isArray(arr)) { console.log('type error!') return } let res = [] for (let i = 0; i < arr.length; i++) { if (res.indexOf(arr[i]) === -1) { res.push(arr[i]) } } return res }
indexOf方法去重2
利用indexOf檢測元素在數(shù)組中第一次出現(xiàn)的位置是否和元素現(xiàn)在的位置相等,如果不等則說明該元素是重復(fù)元素
function unique(arr) { if (!Array.isArray(arr)) { console.log('type error!') return } return Array.prototype.filter.call(arr, function(item, index){ return arr.indexOf(item) === index; }); }
相鄰元素去重
這種方法首先調(diào)用了數(shù)組的排序方法sort(),然后根據(jù)排序后的結(jié)果進(jìn)行遍歷及相鄰元素比對,如果相等則跳過改元素,直到遍歷結(jié)束
function unique(arr) { if (!Array.isArray(arr)) { console.log('type error!') return } arr = arr.sort() let res = [] for (let i = 0; i < arr.length; i++) { if (arr[i] !== arr[i-1]) { res.push(arr[i]) } } return res }
利用對象屬性去重
創(chuàng)建空對象,遍歷數(shù)組,將數(shù)組中的值設(shè)為對象的屬性,并給該屬性賦初始值1,每出現(xiàn)一次,對應(yīng)的屬性值增加1,這樣,屬性值對應(yīng)的就是該元素出現(xiàn)的次數(shù)了
function unique(arr) { if (!Array.isArray(arr)) { console.log('type error!') return } let res = [], obj = {} for (let i = 0; i < arr.length; i++) { if (!obj[arr[i]]) { res.push(arr[i]) obj[arr[i]] = 1 } else { obj[arr[i]]++ } } return res }
set與解構(gòu)賦值去重
ES6中新增了數(shù)據(jù)類型set,set的一個最大的特點(diǎn)就是數(shù)據(jù)不重復(fù)。Set函數(shù)可以接受一個數(shù)組(或類數(shù)組對象)作為參數(shù)來初始化,利用該特性也能做到給數(shù)組去重
function unique(arr) { if (!Array.isArray(arr)) { console.log('type error!') return } return [...new Set(arr)] }
Array.from與set去重
Array.from方法可以將Set結(jié)構(gòu)轉(zhuǎn)換為數(shù)組結(jié)果,而我們知道set結(jié)果是不重復(fù)的數(shù)據(jù)集,因此能夠達(dá)到去重的目的
function unique(arr) { if (!Array.isArray(arr)) { console.log('type error!') return } return Array.from(new Set(arr)) }
總結(jié)
數(shù)組去重是開發(fā)中經(jīng)常會碰到的一個熱點(diǎn)問題。我們可以根據(jù)不同的應(yīng)用場景來選擇不同的實(shí)現(xiàn)方式。
到此這篇關(guān)于JavaScript實(shí)現(xiàn)數(shù)組去重的7種方法的文章就介紹到這了,更多相關(guān)JavaScript 數(shù)組去重內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Bootstrap下拉菜單更改為懸停(hover)觸發(fā)的方法
這篇文章主要為大家詳細(xì)介紹了Bootstrap下拉菜單更改為懸停(hover)觸發(fā)的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05JavaScript類型轉(zhuǎn)換方法及需要注意的問題小結(jié)(挺全面)
JavaScript類型轉(zhuǎn)換方法及需要注意的問題,在js中經(jīng)常需要對數(shù)據(jù)類型的轉(zhuǎn)換操作,需要的朋友可以參考下。2010-11-11js實(shí)現(xiàn)一個可以兼容PC端和移動端的div拖動效果實(shí)例
這篇文章主要介紹了js實(shí)現(xiàn)一個可以兼容PC端和移動端的div拖動效果實(shí)例,具有一定的參考價(jià)值,有需要的可以了解一下。2016-12-12JS實(shí)現(xiàn)div內(nèi)部的文字或圖片自動循環(huán)滾動代碼
在某些情況下需要這樣的功能:使用JS實(shí)現(xiàn)div內(nèi)部的文字或圖片自動循環(huán)滾動,接下來為大家詳細(xì)介紹下實(shí)現(xiàn)方法,感興趣的朋友可以參考下哈2013-04-04