ES6入门教程之Array.from()方法

作者:流年年不夏半殇 时间:2024-04-18 09:51:51 

前言

ES6为Array增加了from函数用来将其他对象转换成数组。

当然,其他对象也是有要求,也不是所有的,可以将两种对象转换成数组。

1.部署了Iterator接口的对象,比如:Set,Map,Array。

2.类数组对象,什么叫类数组对象,就是一个对象必须有length属性,没有length,转出来的就是空数组。

Array.from()方法就是将一个类数组对象或者可遍历对象转换成一个真正的数组。

那么什么是类数组对象呢?所谓类数组对象,最基本的要求就是具有length属性的对象。

1、将类数组对象转换为真正数组:


let arrayLike = {
0: 'tom',
1: '65',
2: '男',
3: ['jane','john','Mary'],
'length': 4
}
let arr = Array.from(arrayLike)
console.log(arr) // ['tom','65','男',['jane','john','Mary']]

那么,如果将上面代码中 length 属性去掉呢?实践证明,答案会是一个长度为0的空数组。

这里将代码再改一下,就是具有 length 属性,但是对象的属性名不再是数字类型的,而是其他字符串型的,代码如下:


let arrayLike = {
'name': 'tom',
'age': '65',
'sex': '男',
'friends': ['jane','john','Mary'],
length: 4
}
let arr = Array.from(arrayLike)
console.log(arr) // [ undefined, undefined, undefined, undefined ]

会发现结果是长度为4,元素均为 undefined 的数组

由此可见,要将一个类数组对象转换为一个真正的数组,必须具备以下条件:

1、该类数组对象必须具有 length 属性,用于指定数组的长度。如果没有 length 属性,那么转换后的数组是一个空数组。

2、该类数组对象的属性名必须为数值型或字符串型的数字

该类数组对象的属性名可以加引号,也可以不加引号

2、将Set结构的数据转换为真正的数组:


let arr = [12,45,97,9797,564,134,45642]
let set = new Set(arr)
console.log(Array.from(set)) // [ 12, 45, 97, 9797, 564, 134, 45642 ]

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

如下:


let arr = [12,45,97,9797,564,134,45642]
let set = new Set(arr)
console.log(Array.from(set, item => item + 1)) // [ 13, 46, 98, 9798, 565, 135, 45643 ]

快速创建一个1~20的数组


Array.from({length:20},(t,i)=>i+1)
// [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20]

模拟生成 1万条数据


// 模拟生成 1万条数据,利用了 Array.from 来快速生成数据
const originNews = Array.from(
{ length: 10000 },
(v, k) => ({ content: `新闻${k}` })
)

3、将字符串转换为数组:


let str = 'hello world!';
console.log(Array.from(str)) // ["h", "e", "l", "l", "o", " ", "w", "o", "r", "l", "d", "!"]

4、Array.from参数是一个真正的数组:


console.log(Array.from([12,45,47,56,213,4654,154]))

像这种情况,Array.from 会返回一个一模一样的新数组

把数组按指定大小进行分组,可以用于分页、数据切割、异步操作数据。


const chunk = (arr, size) =>
Array.from({ length: Math.ceil(arr.length / size) }, (v, i) =>
arr.slice(i * size, i * size + size)
);

来源:https://juejin.im/post/5c946d2251882572e92c4a2d

标签:es6,array.from(),方法
0
投稿

猜你喜欢

  • python贪吃蛇游戏代码

    2023-07-22 04:19:17
  • Go mod包管理工具详解

    2024-04-30 10:08:11
  • python 简单的多线程链接实现代码

    2021-09-24 02:10:02
  • JS中定位 position 的使用实例代码

    2024-05-03 15:05:09
  • 给Notepad++换主题

    2009-05-04 14:43:00
  • 如何使用pycharm连接Databricks的步骤详解

    2023-01-28 23:19:03
  • Golang源码分析之golang/sync之singleflight

    2024-04-25 15:07:26
  • python3 深浅copy对比详解

    2023-11-08 11:12:51
  • 解决Keras 与 Tensorflow 版本之间的兼容性问题

    2022-08-04 08:18:53
  • JavaScript eval() 函数介绍及应用示例

    2024-04-19 10:00:01
  • mysql 各种时间段查询

    2010-01-06 13:37:00
  • JavaScript数字和字符串转换示例

    2024-05-02 16:27:07
  • python读取与写入csv格式文件的示例代码

    2023-08-09 09:07:15
  • Python 使用with上下文实现计时功能

    2022-08-20 02:43:21
  • Python 实现图片转字符画的示例(静态图片,gif皆可)

    2023-04-11 13:42:38
  • Python 图片文字识别的实现之PaddleOCR

    2022-03-12 19:07:58
  • django-rest-framework 自定义swagger过程详解

    2023-01-01 22:05:34
  • C#连接Oracle数据库的多种方法总结

    2024-01-23 12:43:45
  • Pycharm操作Git及GitHub的步骤详解

    2023-02-19 04:34:59
  • IE8 CSS之生成内容

    2008-09-09 22:14:00
  • asp之家 网络编程 m.aspxhome.com