资讯专栏INFORMATION COLUMN

ES6中Array.from()函数详解

zzzmh / 2877人阅读

摘要:注意属性名代表了数组的索引号,如果没有这个索引号,转出来的数组中对应的元素就为空。对象的属性名不能转换成索引号时。可选参数可选参数,执行回调函数时对象。

ES6为Array增加了from函数用来从一个类似数组或可迭代对象中创建一个新的,浅拷贝的数组实例。
不过只可以将一下两种对象转换成数组。
1.部署了Iterator接口的对象,比如:Set,Map,Array。
2.类数组对象,什么叫类数组对象,就是一个对象必须有length属性,没有length,转出来的就是空数组。

1:转换字符串
可以吧ascii的字符串拆解成一个数据,也可以准确的将unicode字符串拆解成数组。

console.log(Array.from("hello world"))
console.log(Array.from("u4f60u597d"))
//h,e,l,l,o, ,w,o,r,l,d
//你,

2:转换set对象
将Set对象的元素转换成一个数组。

const newSet = new Set();
newSet.add(0).add(1).add(2);
console.log(Array.from(newSet ))
//0,1,2

3:转换map
将Map对象的键值对转换成一个一维数组,转换出来的数组元素的序列是:key1,value1,key2,value2,key3,value3.....

const map1 = new Map();
map1.set("k1", 1);
map1.set("k2", 2);
map1.set("k3", 3);
console.log(Array.from(map1))
//k1,1,k2,2,k3,3

4:转换类数组对象
一个类数组对象必须要有length,他们的元素属性名必须是数值或者可以转换成数值的字符。
注意:属性名代表了数组的索引号,如果没有这个索引号,转出来的数组中对应的元素就为空。

console.log(Array.from({
  0: "0",
  1: "1",
  3: "3",
  5: "5"
  length:5
}))
//0,1,,3,,5

如果对象不带length属性,那么转出来就是空数组。

console.log(Array.from({
  0: 0,
  1: 1
}))
//结果就是空数组。


对象的属性名不能转换成索引号时。

console.log(Array.from({
  a: "1",
  b: "2",
  length:2
}))
//结果也是空数组
Array.from可以接受三个参数

我们看定义:

Array.from(arrayLike[, mapFn[, thisArg]])
//arrayLike
//想要转换成数组的伪数组对象或可迭代对象。
//mapFn (可选参数)
//如果指定了该参数,新数组中的每个元素会执行该回调函数。
//thisArg (可选参数)
//可选参数,执行回调函数 mapFn 时 this 对象。

第一个参数上面已经讲了,下面讲剩下的两个参数

第二个参数,map函数
用来对转换中,每一个元素进行加工,并将加工后的结果作为结果数组的元素值。

console.log(Array.from([1, 2, 3, 4, 5], (n) => n + 1))
//2,3,4,5,6

第三个参数,map函数中this指向的对象

该参数可以将被处理的数据和处理对象分离,将各种不同的处理数据的方法封装到不同的的对象中去,处理方法采用相同的名字。在调用Array.from对数据对象进行转换时,可以将不同的处理对象按实际情况进行注入,以得到不同的结果,适合解耦。
相当于:Array.from(obj).map(mapFn, thisArg)

let diObj = {
  handle: function(n){
    return n + 2
  }
}

console.log(Array.from(
  [1, 2, 3, 4, 5], 
  function (x){
    return this.handle(x)
  }, 
  diObj))
//3,4,5,6,7

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/105786.html

相关文章

  • JavaScript数组去重—ES6的两种方式

    摘要:数组的方法方法创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素。可选,执行函数时的值。删除所有的键值对,没有返回值。返回一个布尔值,表示某个键是否在当前对象之中。 说明 JavaScript数组去重这个问题,经常出现在面试题中,以前也写过一篇数组去重的文章,(JavaScript 数组去重的多种方法原理详解)但感觉代码还是有点不够简单,今天和大家再说两种方法,代码...

    FrancisSoung 评论0 收藏0
  • JavaScript数组去重—ES6的两种方式

    摘要:数组的方法方法创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素。可选,执行函数时的值。删除所有的键值对,没有返回值。返回一个布尔值,表示某个键是否在当前对象之中。 说明 JavaScript数组去重这个问题,经常出现在面试题中,以前也写过一篇数组去重的文章,(JavaScript 数组去重的多种方法原理详解)但感觉代码还是有点不够简单,今天和大家再说两种方法,代码...

    lijinke666 评论0 收藏0
  • JavaScript数组去重—ES6的两种方式

    摘要:数组的方法方法创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素。可选,执行函数时的值。删除所有的键值对,没有返回值。返回一个布尔值,表示某个键是否在当前对象之中。 说明 JavaScript数组去重这个问题,经常出现在面试题中,以前也写过一篇数组去重的文章,(JavaScript 数组去重的多种方法原理详解)但感觉代码还是有点不够简单,今天和大家再说两种方法,代码...

    Clect 评论0 收藏0
  • 常用JavaScript小技巧及原理详解

    摘要:使用一元加模拟函数原理对非数值类型的数据使用一元加,会起到与函数相同的效果。中,若判断不为则不再进行下一步操作。使用逻辑或设置默认值逻辑或也属于短路操作,即当第一个操作数可以决定结果时,不再对第二个操作数进行求值。 善于利用JS中的小知识的利用,可以很简洁的编写代码 1. 使用!!模拟Boolean()函数 原理:逻辑非操作一个数据对象时,会先将数据对象转换为布尔值,然后取反,两个!!...

    chnmagnus 评论0 收藏0

发表评论

0条评论

zzzmh

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<