join toString
10年積累的成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站設(shè)計(jì)后付款的網(wǎng)站建設(shè)流程,更有會(huì)昌免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
該兩種方法會(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í)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。