Array.from()方法

Array.from()方法用于将两类对象转为真正的数组:类似数组的对象(array-like object)和可遍历(iterable)的对象(包括 ES6 新增的数据结构 Set 和 Map)。

下面是一个类似数组的对象,Array.from()方法将它转为真正的数组。

  1. let arrayLike = {
  2. '0': 'a',
  3. '1': 'b',
  4. '2': 'c',
  5. length: 3
  6. };
  7. // ES5的写法
  8. var arr1 = [].slice.call(arrayLike); // ['a', 'b', 'c']
  9. // ES6的写法
  10. let arr2 = Array.from(arrayLike); // ['a', 'b', 'c']

实际应用中,常见的类似数组的对象是 DOM 操作返回的 NodeList 集合,以及函数内部的arguments对象。Array.from()方法都可以将它们转为真正的数组。

  1. // NodeList对象
  2. let ps = document.querySelectorAll('p');
  3. Array.from(ps).forEach(function (p) {
  4. console.log(p);
  5. });
  6. // arguments对象
  7. function foo() {
  8. var args = Array.from(arguments);
  9. // ...
  10. }

上面代码中,querySelectorAll方法返回的是一个类似数组的对象,可以将这个对象转为真正的数组,再使用forEach方法。

只要是部署了 Iterator 接口的数据结构,Array.from()方法都能将其转为数组。

  1. Array.from('hello')
  2. // ['h', 'e', 'l', 'l', 'o']
  3. let namesSet = new Set(['a', 'b'])
  4. Array.from(namesSet) // ['a', 'b']

上面代码中,字符串和 Set 结构都具有 Iterator 接口,因此可以被Array.from()方法转为真正的数组。

如果参数是一个真正的数组,Array.from()方法会返回一个一模一样的新数组。

  1. Array.from([1, 2, 3])
  2. // [1, 2, 3]

值得提醒的是,扩展运算符(...)也可以将某些数据结构转为数组。

  1. // arguments对象
  2. function foo() {
  3. const args = [...arguments];
  4. }
  5. // NodeList对象
  6. [...document.querySelectorAll('div')]

扩展运算符背后调用的是遍历器接口(Symbol.iterator),如果一个对象没有部署这个接口,就无法转换。Array.from()方法还支持类似数组的对象。所谓类似数组的对象,本质特征只有一点,即必须有length属性。因此,任何有length属性的对象,都可以通过Array.from()方法转为数组,而此时扩展运算符就无法转换。

  1. Array.from({ length: 3 });
  2. // [ undefined, undefined, undefined ]

上面代码中,Array.from()方法返回了一个具有三个成员的数组,每个位置的值都是undefined。扩展运算符转换不了这个对象。

对于还没有部署该方法的浏览器,可以用Array.prototype.slice方法替代。

  1. const toArray = (() =>
  2. Array.from ? Array.from : obj => [].slice.call(obj)
  3. )();

Array.from()方法还可以接受第二个参数,作用类似于数组的map方法,用来对每个元素进行处理,将处理后的值放入返回的数组。

  1. Array.from(arrayLike, x => x * x);
  2. // 等同于
  3. Array.from(arrayLike).map(x => x * x);
  4. Array.from([1, 2, 3], (x) => x * x)
  5. // [1, 4, 9]

下面的例子是取出一组 DOM 节点的文本内容。

  1. let spans = document.querySelectorAll('span.name');
  2. // map()
  3. let names1 = Array.prototype.map.call(spans, s => s.textContent);
  4. // Array.from()
  5. let names2 = Array.from(spans, s => s.textContent)

下面的例子将数组中布尔值为false的成员转为0

  1. Array.from([1, , 2, , 3], (n) => n || 0)
  2. // [1, 0, 2, 0, 3]

另一个例子是返回各种数据的类型。

  1. function typesOf () {
  2. return Array.from(arguments, value => typeof value)
  3. }
  4. typesOf(null, [], NaN)
  5. // ['object', 'object', 'number']

如果map函数里面用到了this关键字,还可以传入Array.from()方法的第三个参数,用来绑定this

Array.from()可以将各种值转为真正的数组,并且还提供map功能。这实际上意味着,只要有一个原始的数据结构,你就可以先对它的值进行处理,然后转成规范的数组结构,进而就可以使用数量众多的数组方法。

  1. Array.from({ length: 2 }, () => 'jack')
  2. // ['jack', 'jack']

上面代码中,Array.from()方法的第一个参数指定了第二个参数运行的次数。这种特性可以让该方法的用法变得非常灵活。

Array.from()方法的另一个应用是,将字符串转为数组,然后返回字符串的长度。因为它能正确处理各种 Unicode 字符,可以避免 JavaScript 将大于\uFFFF的 Unicode 字符,算作两个字符的 bug。

  1. function countSymbols(string) {
  2. return Array.from(string).length;
  3. }

Array.from()方法相关推荐

  1. JS Array filter()方法

    JS Array filter()方法 js的数据对象有一个fileter()方法,运行传入一个方法,并对数组中的每个元素进行过滤. var arr = [1,2,3,4,5,6]; function ...

  2. ruby array_Ruby中带有示例的Array.select方法

    ruby array Array.select方法 (Array.select Method) In the last articles, we have seen how to iterate ov ...

  3. ruby中、.reject_Ruby中带有示例的Array.reject方法

    ruby中..reject Ruby Array.reject方法 (Ruby Array.reject Method) In the last article, we have seen how w ...

  4. ruby array_Ruby中带有示例的Array.shuffle方法

    ruby array Array.shuffle方法 (Array.shuffle Method) In this article, we will study about Array.shuffle ...

  5. ruby array_在Ruby中使用Array.pop和Array.shift方法从Array中删除元素

    ruby array Ruby Array.pop和Array.shift方法 (Ruby Array.pop and Array.shift methods) If you are reading ...

  6. _.uniq_在Ruby中使用Array.compact和Array.uniq方法从Array中移除元素

    _.uniq Ruby Array.compact和Array.uniq方法 (Ruby Array.compact and Array.uniq Methods) In the last artic ...

  7. ruby .each_Ruby中带有示例的Array.each方法

    ruby .each Ruby Array.each方法 (Ruby Array.each method) Array.each method can be easily termed as a me ...

  8. ruby array_Ruby中带有示例的Array.keep_if方法

    ruby array Ruby Array.keep_if方法 (Ruby Array.keep_if Method) In the last articles, we have studied th ...

  9. ruby array_Ruby中带有示例的Array.delete_if方法

    ruby array Ruby Array.delete_if方法 (Ruby Array.delete_if Method) In the last articles, we have studie ...

  10. python创建数组的方法_numpy创建array的方法汇总

    创建numpy.array,是使用numpy这个核武器的基础,本文尽量汇总常用创建numpy.array的方法. array函数 >>> import numpy as np > ...

最新文章

  1. dlib android
  2. Linux centos7安装nfs及服务端配置
  3. 【HDU 1711】Number Sequence(裸KMP算法)
  4. C++函数声明和定义
  5. 数学--数论--中国剩余定理+扩展中国剩余定理(孙子定理)
  6. quill变html转化,将Quill Delta转换为HTML
  7. 宿舍管理系统项目管理师_2020下半年信息系统项目管理师真题——案例分析(带解析)...
  8. php 怎么从memcache缓存数据中统计某一字段总数,php和memcache统计在线人数的方法...
  9. java解析上的jar包里的pom_Maven引入本地Jar包并打包进War包中的方法
  10. java第三课,流程控制语句
  11. 函数调用过程实例详解
  12. Python基础-day01
  13. 清明节偷偷训练“熊猫烧香”,结果我的电脑为熊猫“献身了”!
  14. Enolsoft PDF Converter with OCR激活版
  15. 打补丁更新不适用计算机,安装补丁“此更新不适用于你的计算机”解决办法
  16. CV LRO mission (LROC introduction)
  17. c c 语言写的四六级词汇系统,2020年6月英语四级考试大纲词汇:C
  18. Matlab_R2016a 中文破解版 安装教程
  19. 群控成为微商月入百万的神器
  20. 【战术性mark】JS 复制内容到剪贴板

热门文章

  1. 算法笔记_056:蓝桥杯练习 未名湖边的烦恼(Java)
  2. Linux安装Swift开发环境
  3. 解决手动运行脚本执行正常而放入crontab后不正常的方法
  4. 我认为的android入门学习策略
  5. 使用lambda去重、map排序、按任意时间间隔(小时、半小时、分钟)进行结果统计
  6. Python 读入Excel表时如何判空NaN
  7. 使用计算机正确开机方法,电脑开关机的正确步骤
  8. 编程指南_halide编程技术指南(连载一)
  9. Java 项目中一种简单的动态修改配置即时生效的方式 WatchService
  10. Mysql查询数据(单表查询)