JS數(shù)組扁平化(flat)方法總結(jié)詳解
更新時間:2019年06月24日 10:19:25 作者:神三元
這篇文章主要介紹了JS數(shù)組扁平化(flat)方法總結(jié)詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,,需要的朋友可以參考下
需求:多維數(shù)組=>一維數(shù)組
let ary = [1, [2, [3, [4, 5]]], 6]; let str = JSON.stringify(ary);
第0種處理:直接的調(diào)用
arr_flat = arr.flat(Infinity);
第一種處理
ary = str.replace(/(\[\]))/g, '').split(',');
第二種處理
str = str.replace(/(\[\]))/g, ''); str = '[' + str + ']'; ary = JSON.parse(str);
第三種處理:遞歸處理
let result = [];
let fn = function(ary) {
for(let i = 0; i < ary.length; i++) }{
let item = ary[i];
if (Array.isArray(ary[i])){
fn(item);
} else {
result.push(item);
}
}
}
第四種處理:用 reduce 實現(xiàn)數(shù)組的 flat 方法
function flatten(ary) {
return ary.reduce((pre, cur) => {
return pre.concat(Array.isArray(cur) ? flatten(cur) : cur);
})
}
let ary = [1, 2, [3, 4], [5, [6, 7]]]
console.log(ary.MyFlat(Infinity))
第五種處理:擴展運算符
while (ary.some(Array.isArray)) {
ary = [].concat(...ary);
}
這是一個比較實用而且很容易被問到的問題,歡迎大家交流補充。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
?JavaScript+HarmonyOS?實現(xiàn)一個手繪板
這篇文章主要介紹了?JavaScript+HarmonyOS?實現(xiàn)一個手繪板,利用openHarmony內(nèi)置的API?cnavas組件實現(xiàn),具體詳細內(nèi)容需要的小伙伴可以參考一下2022-07-07
微信小程序?qū)崿F(xiàn)虎年春節(jié)頭像制作
春節(jié)來臨之際,看到有網(wǎng)友分享了網(wǎng)頁版的虎年頭像制作工具。本文將為大家介紹一個虎年春節(jié)頭像制作小程序,文中的示例代碼講解詳細,需要的可以參考一下2022-02-02

