javscript 數(shù)組扁平化的實(shí)現(xiàn)
join toString
該兩種方法會(huì)將數(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"]
缺點(diǎn): 轉(zhuǎn)換為一維數(shù)組后數(shù)組元素轉(zhuǎn)換為字符串,需要重新轉(zhuǎn)換數(shù)組元素為Number類型
es6 flat
Array.prototype.flat()用于將嵌套的數(shù)組“拉平”,變成一維的數(shù)組。該方法返回一個(gè)新數(shù)組,對(duì)原數(shù)據(jù)沒有影響
flat()默認(rèn)只會(huì)“拉平”一層,如果想要“拉平”多層的嵌套數(shù)組,可以將flat()方法的參數(shù)寫成一個(gè)整數(shù),表示想要拉平的層數(shù),默認(rèn)為1。
如果不管有多少層嵌套,都要轉(zhuǎn)成一維數(shù)組,可以用Infinity關(guān)鍵字作為參數(shù)。
arr.flat(Infinity); // [1, 2, 3, 4, 5, 6]
缺點(diǎn): 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]
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JS操作數(shù)據(jù)庫(kù)的實(shí)例代碼
這篇文章介紹了JS操作數(shù)據(jù)庫(kù)的實(shí)例代碼,有需要的朋友可以參考一下2013-10-10
js實(shí)現(xiàn)彈出框的拖拽效果實(shí)例代碼詳解
本文通過實(shí)例代碼給大家介紹了js實(shí)現(xiàn)彈出框的拖拽效果,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2019-04-04
JavaScript實(shí)現(xiàn)簡(jiǎn)單隨機(jī)點(diǎn)名器
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)簡(jiǎn)單隨機(jī)點(diǎn)名器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-11-11
uniapp項(xiàng)目實(shí)踐自定義分享組件示例
這篇文章主要為大家介紹了uniapp項(xiàng)目實(shí)踐自定義分享組件示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09
function, new function, new Function之間的區(qū)別
function, new function, new Function之間的區(qū)別...2007-03-03
js創(chuàng)建數(shù)組的簡(jiǎn)單方法
下面小編就為大家?guī)硪黄狫S創(chuàng)建數(shù)組的簡(jiǎn)單方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-07-07
js 調(diào)用百度地圖api并在地圖上進(jìn)行打點(diǎn)添加標(biāo)注
上邊有一個(gè)標(biāo)題,下邊分成兩塊,左邊是地圖。并且地圖上有兩個(gè)點(diǎn),點(diǎn)擊兩個(gè)點(diǎn)有相應(yīng)的提示信息,具體實(shí)現(xiàn)如下2014-05-05
盤點(diǎn)7個(gè)簡(jiǎn)單但棘手的JavaScript面試問題分析
這篇文章主要為大家介紹了盤點(diǎn)7個(gè)簡(jiǎn)單但棘手的JavaScript面試問題分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11

