本文摘自PHP中文网,作者coldplay.xixi,侵删。

相关学习推荐:javascript视频教程
前言
从去年发现字符串的replace方法有很多神奇用法的时候,就想做这个系列,但是一直没空,也没有想到很好的名字,就搁置了。上周五刷题的时候看评论有个解决方法是用Array.from一行解决,而且效率还挺高的。于是啃了一下文档和博客,搞清楚了之后就想正好可以开始这个系列了。而且数组是我们开发中最常用的数据结构之一,作为生成数组的方法之一,以from开始也蛮意思。系列名字就先凑合这么叫吧。
- 基础语法
定义:from() 方法用于通过拥有 length 属性的对象或可迭代的对象来返回一个数组。
语法:Array.from(object, mapFunction, thisValue)
参数 | 描述 |
object | 必需,要转换为数组的对象。 |
mapFunction | 可选,数组中每个元素要调用的函数。 |
thisValue | 可选,映射函数(mapFunction)中的 this 对象。 |
- 示例用法
1. 将类数组转化为数组
1 2 3 4 5 6 7 8 9 10 11 |
|
这是我们平时最常用的功能,写这些示例的时候我还奇怪:为什么map能转成数组而object只能转为空数组。当我查看菜鸟教程,看到上述定义我才明白。object既没有length也不是可迭代对象,我之前以为object也是可迭代对象,毕竟都可以用for-in嘛。但其实es6的object不是可迭代对象,这里不多赘述,有兴趣的同学可以去查一下。
2. 数组深拷贝(一行代码)
1 2 3 4 5 6 7 |
|
这里主要用到了Array.from的第二个参数mapFunction,mapFunction默认传两个参数,数组的值和下标。
3. 数组去重
1 2 3 |
|
这也是from最基本,也是我们最常用的功能之一。
4. from的其他用法
再看一遍from定义:from() 方法用于通过拥有 length 属性的对象或可迭代的对象来返回一个数组。拥有length就行?试一试
1 |
|
可以,那他有什么用呢?第一,像上面代码,可以很方便生成在一定范围,有一定规则的数组
1 |
|
第二,数组的初始化。比如你想生成指定长度的对象数组。第一反应是什么?fill吗?
1 2 |
|
这里的每个对象其实都是同一个,你修改一个其他自然会跟着改变,但很多时候我们需要的并不是这样的。
1 2 |
|
这两个方法可以根据需求使用。
5. from的进阶用法
上面的内容其实层层递进下来都是为了更好的理解下面的解题思路。
LeetCode第867题:
给定一个矩阵 A
, 返回 A
的转置矩阵。
矩阵的转置是指将矩阵的主对角线翻转,交换矩阵的行索引与列索引。
示例 1: 输入:[[1,2,3],[4,5,6],[7,8,9]] 输出:[[1,4,7],[2,5,8],[3,6,9]] 示例 2: 输入:[[1,2,3],[4,5,6]] 输出:[[1,4],[2,5],[3,6]]
当时第一反应这就不是索引互换吗?贼简单。于是写了如下代码
1 2 3 4 5 6 7 8 9 10 11 12 |
|
执行代码:通过,提交:失败。卧槽?看一下错误提示,发现忽略了示例2这种,“长宽”不等的情况。转换思路,内外循环翻转。最外循环每执行一次即一列当做行。执行,通过。
不过这版看起来太捞了,而且执行时间太慢。但毕竟自己实现了,可以去评论区找一下其他思路。
下面这个就是看评论区大神实现,第一次都没看懂。
1 |
|
{length:A[0].length},是以给定矩阵的宽作为转置矩阵的长,为了满足“拥有 length 属性的对象”这一条件。(_v,i)=>A.map(v=>v[i]),取给定矩阵的列作为转置矩阵的行。核心思路和我第二版是一样的,但是实现方式和技巧就秀太多了。而且执行时间也较短,膜拜大神。
想了解更多编程学习,敬请关注php培训栏目!
以上就是需要知道的JS数组之Array.from的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
更多相关阅读请进入《JS数组》频道 >>

Vue.js 设计与实现 基于Vue.js 3 深入解析Vue.js 设计细节
本书对 Vue.js 3 技术细节的分析非常可靠,对于需要深入理解 Vue.js 3 的用户会有很大的帮助。——尤雨溪,Vue.js作者