javscript 數(shù)組扁平化的實現(xiàn)
join toString
該兩種方法會將數(shù)組元素的類型轉(zhuǎn)換為字符串
var arr = [1, [2, [3, [4, 5]]], 6]; console.log(arr.join()); //1,2,3,4,5,6 console.log(arr.toString()); //1,2,3,4,5,6 var flatArr = arr.join().split(','); // ["1", "2", "3", "4", "5", "6"] var flatArr = arr.toString().split(',');// ["1", "2", "3", "4", "5", "6"]
缺點: 轉(zhuǎn)換為一維數(shù)組后數(shù)組元素轉(zhuǎn)換為字符串,需要重新轉(zhuǎn)換數(shù)組元素為Number類型
es6 flat
Array.prototype.flat()用于將嵌套的數(shù)組“拉平”,變成一維的數(shù)組。該方法返回一個新數(shù)組,對原數(shù)據(jù)沒有影響
flat()默認只會“拉平”一層,如果想要“拉平”多層的嵌套數(shù)組,可以將flat()方法的參數(shù)寫成一個整數(shù),表示想要拉平的層數(shù),默認為1。
如果不管有多少層嵌套,都要轉(zhuǎn)成一維數(shù)組,可以用Infinity關(guān)鍵字作為參數(shù)。
arr.flat(Infinity); // [1, 2, 3, 4, 5, 6]
缺點: flat 方法的兼容需要考慮下
reduce 遞歸遍歷
function flatten(arr) { return arr.reduce((acc, cur)=> { // 遇到嵌套就遞歸 return acc.concat(Array.isArray(cur) ? flatten(cur) : cur); }, []); } console.log(flatten(arr)); // [1, 2, 3, 4, 5, 6]
遞歸遍歷
function flatten(arr) { while (arr.some(item => Array.isArray(item))) { arr = [].concat(...arr); } return arr; } console.log(flatten(arr)); // [1, 2, 3, 4, 5, 6]
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
對存在JavaScript隱式類型轉(zhuǎn)換的四種情況的總結(jié)(必看篇)
下面小編就為大家?guī)硪黄獙Υ嬖贘avaScript隱式類型轉(zhuǎn)換的四種情況的總結(jié)(必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-08-08游戲開發(fā)中如何使用CocosCreator進行音效處理
這篇文章主要介紹了游戲開發(fā)中如何使用CocosCreator進行音效處理,并對音效組件進行封裝,方便以后使用,同學(xué)們看完之后,一定要親手實驗一下2021-04-04