JS數(shù)組降維的幾種方法詳解
二維數(shù)組降維
使用數(shù)組實(shí)例方法concat和ES6擴(kuò)展運(yùn)算符降維
let arr=[1,2,[3,4],5]; let arr1=[].concat(...arr); //先使用擴(kuò)展運(yùn)算符打散最外邊的數(shù)組,concat自帶打散粘合數(shù)組的功能 console.log(arr1); // [1, 2, 3, 4, 5] //ES6之前用apply打散數(shù)據(jù)的兼容性寫法 var arr2=[1,2,[3,4],5]; var arr3=[].concat.apply([],arr2); console.log(arr3); // [1, 2, 3, 4, 5]
多維數(shù)組降維
遞歸降維
//幾種利用數(shù)組函數(shù)遞歸降維的寫法
//some&concat
//利用some檢查數(shù)組中是否含有數(shù)組有就在調(diào)用自己進(jìn)行降維
function fun(arr){
arr=[].concat(...arr);
//再檢查降維后的數(shù)組中是否還包含子數(shù)組
let hasArray=arr.some(function(elem){
return Array.isArray(elem);
})
if(hasArray){ //如果包含子數(shù)組
arr=fun(arr);//就只能再降維一次,直到檢查不再包含子數(shù)組為止
}
return arr;
};
//forEach&instanceof
//對(duì)數(shù)組每個(gè)元素進(jìn)行判斷看其是不是數(shù)組是在繼續(xù)調(diào)用自己,不是把他放進(jìn)提前準(zhǔn)備的空數(shù)組中
function fun2(arr){
let ret = [];
let toArr = function(arr){
arr.forEach(function(item){
item instanceof Array ? toArr(item) : ret.push(item);
});
}
toArr(arr);
return ret;
}
//reduce&concat
//最后準(zhǔn)備一個(gè)空數(shù)組,看傳入數(shù)組中的每一項(xiàng)是不是數(shù)組是就重新調(diào)用自己不是就用concat匯總到空數(shù)組中
function fun3(sarr){
return sarr.reduce((pre,val)=>{
return Array.isArray(val) ? pre.concat(fun3(val)): pre.concat(val)
},[])
}
Array.prototype.flat()
ES10 新增Array.prototype.flat(),用于將嵌套的數(shù)組打散,變成一維的數(shù)組。該方法返回一個(gè)新數(shù)組,對(duì)原數(shù)據(jù)沒(méi)有影響。
var arr1 = [1, 2, [3, 4]]; arr1.flat(); // [1, 2, 3, 4] var arr2 = [1, 2, [3, 4, [5, 6]]]; arr2.flat(); // [1, 2, 3, 4, [5, 6]] var arr3 = [1, 2, [3, 4, [5, 6]]]; arr3.flat(2); // [1, 2, 3, 4, 5, 6] //使用 Infinity 作為深度,展開(kāi)任意深度的嵌套數(shù)組 arr3.flat(Infinity); // [1, 2, 3, 4, 5, 6]
到此這篇關(guān)于JS數(shù)組降維的幾種方法的文章就介紹到這了,更多相關(guān)JS數(shù)組降維內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
javascript 禁止復(fù)制網(wǎng)頁(yè)
常見(jiàn)的一些禁止復(fù)制網(wǎng)頁(yè)的代碼,但破解方法也不見(jiàn)容易,這里就不說(shuō)了,可以看本站以前發(fā)布的文章。2009-06-06
快速掌握WordPress中加載JavaScript腳本的方法
這篇文章主要介紹了快速掌握WordPress中加載JavaScript腳本的方法,以及響應(yīng)的CSS樣式加載方法的簡(jiǎn)介,需要的朋友可以參考下2015-12-12
JavaScript中輸出</script>標(biāo)簽的方法
這篇文章主要介紹了JavaScript中輸出</script>標(biāo)簽的方法,在一些廣告代碼中經(jīng)常會(huì)用到這個(gè)小技巧,需要的朋友可以參考下2014-08-08
JavaScript實(shí)現(xiàn)內(nèi)容滾動(dòng)與導(dǎo)航標(biāo)簽互動(dòng)關(guān)聯(lián)方案
這篇文章主要介紹了JavaScript實(shí)現(xiàn)內(nèi)容滾動(dòng)與導(dǎo)航標(biāo)簽互動(dòng)關(guān)聯(lián)方案,主要根據(jù)滾動(dòng)左側(cè)內(nèi)容,關(guān)聯(lián)激活右側(cè)導(dǎo)航節(jié)點(diǎn)展開(kāi)相應(yīng)介紹,需要的小伙伴可以參考一下2022-06-06
10個(gè)很少使用的JavaScript?Console方法分享
你一定聽(tīng)說(shuō)過(guò)?console.log()?,而且可能一直在使用它,在本文中,我們將探討一些最有用的控制臺(tái)方法,以及它們?cè)跀?shù)據(jù)可視化、調(diào)試等方面的用途,感興趣的小伙伴可以學(xué)習(xí)一下2023-09-09
js實(shí)現(xiàn)倒計(jì)時(shí)秒殺效果
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)倒計(jì)時(shí)秒殺效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-12-12
layui 根據(jù)后臺(tái)數(shù)據(jù)動(dòng)態(tài)創(chuàng)建下拉框并同時(shí)默認(rèn)選中的實(shí)例
今天小編就為大家分享一篇layui 根據(jù)后臺(tái)數(shù)據(jù)動(dòng)態(tài)創(chuàng)建下拉框并同時(shí)默認(rèn)選中的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09
JS實(shí)現(xiàn)的系統(tǒng)調(diào)色板完整實(shí)例
這篇文章主要介紹了JS實(shí)現(xiàn)的系統(tǒng)調(diào)色板,結(jié)合完整實(shí)例形式分析了js實(shí)現(xiàn)調(diào)色板效果的具體步驟與實(shí)現(xiàn)技巧,涉及js數(shù)值計(jì)算與頁(yè)面元素操作的方法,需要的朋友可以參考下2016-12-12

