av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

JS數(shù)組降維的實(shí)現(xiàn)Array.prototype.concat.apply([], arr)

瀏覽:138日期:2024-05-11 14:58:13

把多維數(shù)組(尤其是二維數(shù)組)轉(zhuǎn)化為一維數(shù)組是業(yè)務(wù)開(kāi)發(fā)中的常用邏輯,最近跟著黃軼老師學(xué)習(xí)Vue2.6.1.1版本源碼時(shí),看到源碼對(duì)二維數(shù)組降維的代碼,所以這里來(lái)寫一篇,記錄一下,加強(qiáng)印象

二維數(shù)組降為一維數(shù)組

循環(huán)降維

let children = [1, 2, 3, [4, 5, 6], 7, 8, [9, 10]];function simpleNormalizeChildren(children) { let reduce = []; for (let i = 0; i < children.length; i++) { if (Array.isArray(children[i])) { for (let j = 0; j < children[i].length; j++) { reduce.push(children[i][j]); } } else { reduce.push(children[i]); } } return reduce;}simpleNormalizeChildren(children) // [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

此方法思路簡(jiǎn)單,利用雙重循環(huán)遍歷二維數(shù)組中的每個(gè)元素并放到新數(shù)組中。

concat降維

MDN上對(duì)于concat的介紹

“concat creates a new array consisting of the elements in the object on which it is called, followed in order by, for each argument, the elements of that argument (if the argument is an array) or the argument itself (if the argument is not an array).”

concat

如果concat方法的參數(shù)是一個(gè)元素,該元素會(huì)被直接插入到新數(shù)組中;如果參數(shù)是一個(gè)數(shù)組,該數(shù)組的各個(gè)元素將被插入到新數(shù)組中;將該特性應(yīng)用到代碼中:

let children = [1, 2, 3, [4, 5, 6], 7, 8, [9, 10]];function simpleNormalizeChildren(children) { let reduce = []; for (let i = 0; i < children.length; i++) { reduce = reduce.concat(children[i]); } return reduce;}simpleNormalizeChildren(children) // [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

children 的元素如果是一個(gè)數(shù)組,作為concat方法的參數(shù),數(shù)組中的每一個(gè)子元素會(huì)被獨(dú)立插入進(jìn)新數(shù)組。利用concat方法,我們將雙重循環(huán)簡(jiǎn)化為了單重循環(huán)。

apply和concat降維

MDN上對(duì)于apply方法的介紹

“The apply() method calls a function with a given this value and arguments provided as an array.”

apply

apply方法會(huì)調(diào)用一個(gè)函數(shù),apply方法的第一個(gè)參數(shù)會(huì)作為被調(diào)用函數(shù)的this值,apply方法的第二個(gè)參數(shù)(一個(gè)數(shù)組,或類數(shù)組的對(duì)象)會(huì)作為被調(diào)用對(duì)象的arguments值,也就是說(shuō)該數(shù)組的各個(gè)元素將會(huì)依次成為被調(diào)用函數(shù)的各個(gè)參數(shù);將該特性應(yīng)用到代碼中:

let children = [1, 2, 3, [4, 5, 6], 7, 8, [9, 10]];function simpleNormalizeChildren(children) { return Array.prototype.concat.apply([], children);}simpleNormalizeChildren(children) // [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

children作為apply方法的第二個(gè)參數(shù),本身是一個(gè)數(shù)組,數(shù)組中的每一個(gè)元素(還是數(shù)組,即二維數(shù)組的第二維)會(huì)被作為參數(shù)依次傳入到concat中,效果等同于[].concat(1, 2, 3, [4, 5, 6], 7, 8, [9, 10])。利用apply方法,我們將單重循環(huán)優(yōu)化為了一行代碼

Vue2.6.11版本源碼降維

let children = [1, 2, 3, [4, 5, 6], 7, 8, [9, 10]];// :any 可以去掉 這里是Vue通過(guò)Flow指定傳入的參數(shù)類型可以是任意類型function simpleNormalizeChildren(children: any) { for (let i = 0; i < children.length; i++) { if (Array.isArray(children[i])) { return Array.prototype.concat.apply([], children); } } return children;}simpleNormalizeChildren(children); // [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

多維數(shù)組降為一維數(shù)組

遞歸降維

遞歸函數(shù)就是在函數(shù)體內(nèi)調(diào)用自己;

遞歸函數(shù)的使用要注意函數(shù)終止條件避免死循環(huán);

// 多維數(shù)組let children = [1, [2,3], [4, [5, 6, [7, 8]]], [9, 10]];function simpleNormalizeChildren(children) { for (let i = 0; i < children.length; i++) { if (Array.isArray(children[i])) { children = Array.prototype.concat.apply([], children); for(let j =0; j<children.length; j++) { simpleNormalizeChildren(children) } } } return children;}simpleNormalizeChildren(children); // [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

到此這篇關(guān)于JS數(shù)組降維的實(shí)現(xiàn)Array.prototype.concat.apply([], arr)的文章就介紹到這了,更多相關(guān)JS數(shù)組降維內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: JavaScript
主站蜘蛛池模板: aaaaa级片| 亚洲免费精品视频 | 亚洲天堂久久 | 91免费版看片 | 一区二区三区欧美日韩 | 久久精品欧美一区二区三区不卡 | 精品九九九 | 黄a视频| 国产资源在线观看 | 国产精品麻豆免费版 | 中文字幕视频 | 日本在线免费观看视频 | 国产一区二区三区在线视频 | 日韩视频免费 | a视频 | www.成人| 国产91清纯白嫩初高中在线观看 | 国产精品2 | 精品国产一区二区三区久久久蜜月 | 五月天黄色网 | 午夜黄色大片 | aaa黄色片| 日韩aaaa | 日本免费视频 | 亚洲成人免费观看 | 国产日韩精品一区二区 | 日本在线www | 五月婷婷在线观看 | 一级黄色大片 | 久久精品欧美一区二区三区不卡 | 久久精品在线 | 成人夜色 | 四虎在线播放 | 久久黄色网 | 特级丰满少妇一级aaaa爱毛片 | 亚洲成人欧美 | 日本一区二区不卡 | 国产精品美女久久久久久久久 | 免费的黄色小视频 | 一级黄色片免费 | 欧美va亚洲va |