优雅的数组降维——Javascript中apply方法的妙用
2015-10-12 12:55
387 查看
将多维数组(尤其是二维数组)转化为一维数组是业务开发中的常用逻辑,除了使用朴素的循环转换以外,我们还可以利用Javascript的语言特性实现更为简洁优雅的转换。本文将从朴素的循环转换开始,逐一介绍三种常用的转换方法,并借此简单回顾Array.prototype.concat方法和Function.prototype.apply方法。
以下代码将以把二维数组降维到一维数组为例。
1. 朴素的转换
此方法思路简单,利用双重循环遍历二维数组中的每个元素并放到新数组中。
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方法的参数是一个元素,该元素会被直接插入到新数组中;如果参数是一个数组,该数组的各个元素将被插入到新数组中;将该特性应用到代码中:
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值,也就是说该数组的各个元素将会依次成为被调用函数的各个参数;将该特性应用到代码中:
arr作为apply方法的第二个参数,本身是一个数组,数组中的每一个元素(还是数组,即二维数组的第二维)会被作为参数依次传入到concat中,效果等同于[].concat([1,2], [3,4], [5,6])。
利用apply方法,我们将单重循环优化为了一行代码,很简洁有型有木有啊~
读者也可参照本文思路,自己利用递归实现N维数组降维的逻辑。
(全文完)
以下代码将以把二维数组降维到一维数组为例。
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维数组降维的逻辑。
(全文完)
相关文章推荐
- IOS 页面传值的方法
- Android界面View及ViewGroup学习 《转载》
- 弄App Store提示和技巧推荐
- IOS使用XMPP最新教程(五)添加好友和接受好友请求
- Android开机启动Activity或者Service方法
- ios归档
- 使用CocosBuilder时,成员变量命名参考
- iOS---TextField知多少
- Android实现获取SERIAL信息的方法
- 日报2015/10/12(极客学院安卓视频学习)
- android studio增量包升级
- ios项目重命名
- 关于微信支付IWXAPIEventHandler接口中onresp不能调用的问题
- Android视图绘制流程完全解析,带你一步步深入了解View(二)
- iOS iOS7越狱
- Android LayoutInflater原理分析,带你一步步深入了解View(一)
- android社交第三方应用分享
- iOS 处理服务器返回的浮点数数据
- iOS9适配必看指南
- iOS-Git使用详解