微信号:FrontDev

介绍:分享 Web 前端相关的技术文章、工具资源、精选课程、热点资讯

优雅的数组降维——Javascript中apply方法的妙用

2016-02-22 21:00 前端大全

(点击上方,可快速关注)

作者:ralph_zhu 

网址:http://www.cnblogs.com/front-end-ralph/p/4871332.html


将多维数组(尤其是二维数组)转化为一维数组是业务开发中的常用逻辑,除了使用朴素的循环转换以外,我们还可以利用Javascript的语言特性实现更为简洁优雅的转换。本文将从朴素的循环转换开始,逐一介绍三种常用的转换方法,并借此简单回顾Array.prototype.concat方法和Function.prototype.apply方法。


以下代码将以把二维数组降维到一维数组为例。


1. 朴素的转换


function reduceDimension(arr) {

    var reduced = [];

    for (var i = 0; i < arr.length; i++) {

        for (var j = 0; j < arr[i].length; j++) {

            reduced.push(arr[i][j]);

        }

    }

    return reduced;

}


此方法思路简单,利用双重循环遍历二维数组中的每个元素并放到新数组中。


2. 利用concat转换


先来回顾一下MDN上对于该方法的介绍:


“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).”

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/concat


即如果concat方法的参数是一个元素,该元素会被直接插入到新数组中;如果参数是一个数组,该数组的各个元素将被插入到新数组中;将该特性应用到代码中:


function reduceDimension(arr) {

    var reduced = [];

    for (var i = 0; i < arr.length; i++){

        reduced = reduced.concat(arr[i]);

    }

    return reduced;

}


arr的每一个元素都是一个数组,作为concat方法的参数,数组中的每一个子元素又都会被独立插入进新数组。


利用concat方法,我们将双重循环简化为了单重循环。


3. 利用apply和concat转换


按照惯例,先来回顾一下MDN上对于apply方法的介绍:

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

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function/apply


即apply方法会调用一个函数,apply方法的第一个参数会作为被调用函数的this值,apply方法的第二个参数(一个数组,或类数组的对象)会作为被调用对象的arguments值,也就是说该数组的各个元素将会依次成为被调用函数的各个参数;将该特性应用到代码中:


function reduceDimension(arr) {

    return Array.prototype.concat.apply([], arr);

}


arr作为apply方法的第二个参数,本身是一个数组,数组中的每一个元素(还是数组,即二维数组的第二维)会被作为参数依次传入到concat中,效果等同于[].concat([1,2], [3,4], [5,6])。

利用apply方法,我们将单重循环优化为了一行代码,很简洁有型有木有啊~


读者也可参照本文思路,自己利用递归实现N维数组降维的逻辑。



本文属于「前端大全」Javascript 分类。

回复 Javascript 查看更多 Javascript  技术干货。




【今日微信公号推荐↓】

更多推荐请看值得关注的技术和设计公众号


其中推荐了包括技术设计极客 和 IT相亲相关的热门公众号。技术涵盖:Python、Web前端、Java、安卓、iOS、PHP、C/C++、.NET、Linux、数据库、运维、大数据、算法、IT职场等。点击《值得关注的技术和设计公众号》,发现精彩!

 
前端大全 更多文章 5个典型的JavaScript面试题(上) Limu:JavaScript的那些书 Web开发:我希望得到的编程学习路线图 JavaScript基础工具清单 常用排序算法之JavaScript实现
猜您喜欢 10 种机器学习算法的要点 R语言入门第四讲:用cbind\/rbind结合向量 Linux模块化机制和module_init [有奖活动]“猴年马月”终于到了!当年那些遥遥无期的愿望你还记得么? 从贝叶斯的角度看正则项