摘要:注意属性名代表了数组的索引号,如果没有这个索引号,转出来的数组中对应的元素就为空。对象的属性名不能转换成索引号时。可选参数可选参数,执行回调函数时对象。
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数组去重这个问题,经常出现在面试题中,以前也写过一篇数组去重的文章,(JavaScript 数组去重的多种方法原理详解)但感觉代码还是有点不够简单,今天和大家再说两种方法,代码...
摘要:数组的方法方法创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素。可选,执行函数时的值。删除所有的键值对,没有返回值。返回一个布尔值,表示某个键是否在当前对象之中。 说明 JavaScript数组去重这个问题,经常出现在面试题中,以前也写过一篇数组去重的文章,(JavaScript 数组去重的多种方法原理详解)但感觉代码还是有点不够简单,今天和大家再说两种方法,代码...
摘要:数组的方法方法创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素。可选,执行函数时的值。删除所有的键值对,没有返回值。返回一个布尔值,表示某个键是否在当前对象之中。 说明 JavaScript数组去重这个问题,经常出现在面试题中,以前也写过一篇数组去重的文章,(JavaScript 数组去重的多种方法原理详解)但感觉代码还是有点不够简单,今天和大家再说两种方法,代码...
摘要:使用一元加模拟函数原理对非数值类型的数据使用一元加,会起到与函数相同的效果。中,若判断不为则不再进行下一步操作。使用逻辑或设置默认值逻辑或也属于短路操作,即当第一个操作数可以决定结果时,不再对第二个操作数进行求值。 善于利用JS中的小知识的利用,可以很简洁的编写代码 1. 使用!!模拟Boolean()函数 原理:逻辑非操作一个数据对象时,会先将数据对象转换为布尔值,然后取反,两个!!...
阅读 2161·2023-04-26 00:00
阅读 3274·2021-09-24 10:37
阅读 3538·2021-09-07 09:58
阅读 1527·2019-08-30 15:56
阅读 2225·2019-08-30 13:11
阅读 2318·2019-08-29 16:38
阅读 969·2019-08-29 12:58
阅读 1888·2019-08-27 10:54