五个超好用的Array.from()用途(详解)

五个超好用的Array.from()用途(详解)

任何一种编程语言都具有超出基本用法的功能,它得益于成功的设计和试图去解决广泛问题。

JavaScript 中有一个这样的函数:Array.from:允许在 JavaScript 集合(如: 数组、类数组对象、或者是字符串、map 、set 等可迭代对象) 上进行有用的转换。

【相关课程推荐:JavaScript视频教程】

在本文中,我将描述5个有用且有趣的 Array.from() 用例。

1. 介绍

在开始之前,我们先回想一下 Array.from() 的作用。语法:

Array.from(arrayLike[, mapFunction[, thisArg]])

登录后复制

arrayLike:必传参数,想要转换成数组的伪数组对象或可迭代对象。

mapFunction:可选参数,mapFunction(item,index){…} 是在集合中的每个项目上调用的函数。返回的值将插入到新集合中。

thisArg:可选参数,执行回调函数 mapFunction 时 this 对象。这个参数很少使用。

例如,让我们将类数组的每一项乘以2:

const someNumbers = { '0': 10, '1': 15, length: 2 };Array.from(someNumbers, value => value * 2); // => [20, 30]

登录后复制

2.将类数组转换成数组

Array.from() 第一个用途:将类数组对象转换成数组。

通常,你会碰到的类数组对象有:函数中的 arguments 关键字,或者是一个 DOM 集合。

在下面的示例中,让我们对函数的参数求和:

function sumArguments() {    return Array.from(arguments).reduce((sum, num) => sum + num);}sumArguments(1, 2, 3); // => 6

登录后复制

Array.from(arguments) 将类数组对象 arguments 转换成一个数组,然后使用数组的 reduce 方法求和。

此外,Array.from() 的第一个参数可以是任意一个可迭代对象,我们继续看一些例子:

Array.from('Hey');                   // => ['H', 'e', 'y']Array.from(new Set(['one', 'two'])); // => ['one', 'two']const map = new Map();map.set('one', 1)map.set('two', 2);Array.from(map); // => [['one', 1], ['two', 2]]

登录后复制

3.克隆一个数组

在 JavaScript 中有很多克隆数组的方法。正如你所想,Array.from() 可以很容易的实现数组的浅拷贝。

const numbers = [3, 6, 9];const numbersCopy = Array.from(numbers);numbers === numbersCopy; // => false

登录后复制

Array.from(numbers) 创建了对 numbers 数组的浅拷贝,numbers === numbersCopy 的结果是 false,意味着虽然 numbers 和 numbersCopy 有着相同的项,但是它们是不同的数组对象。

是否可以使用 Array.from() 创建数组的克隆,包括所有嵌套的?挑战一下!

function recursiveClone(val) {    return Array.isArray(val) ? Array.from(val, recursiveClone) : val;}const numbers = [[0, 1, 2], ['one', 'two', 'three']];const numbersClone = recursiveClone(numbers);numbersClone; // => [[0, 1, 2], ['one', 'two', 'three']]numbers[0] === numbersClone[0] // => false

登录后复制

recursiveClone() 能够对数组的深拷贝,通过判断 数组的 item 是否是一个数组,如果是数组,就继续调用 recursiveClone() 来实现了对数组的深拷贝。

你能编写一个比使用 Array.from() 递归拷贝更简短的数组深拷贝吗?如果可以的话,请写在下面的评论区。

4. 使用值填充数组

如果你需要使用相同的值来初始化数组,那么 Array.from() 将是不错的选择。

我们来定义一个函数,创建一个填充相同默认值的数组:

const length = 3;const init   = 0;const result = Array.from({ length }, () => init);result; // => [0, 0, 0]

登录后复制

result 是一个新的数组,它的长度为3,数组的每一项都是0。调用 Array.from() 方法,传入一个类数组对象 { length } 和 返回初始化值的 mapFunction 函数。

但是,有一个替代方法 array.fill() 可以实现同样的功能。

const length = 3;const init   = 0;const result = Array(length).fill(init);fillArray2(0, 3); // => [0, 0, 0]

登录后复制

fill() 使用初始值正确填充数组。

4.1 使用对象填充数组

当初始化数组的每个项都应该是一个新对象时,Array.from() 是一个更好的解决方案:

const length = 3;const resultA = Array.from({ length }, () => ({}));const resultB = Array(length).fill({});resultA; // => [{}, {}, {}]resultB; // => [{}, {}, {}]resultA[0] === resultA[1]; // => falseresultB[0] === resultB[1]; // => true

登录后复制

由 Array.from 返回的 resultA 使用不同空对象实例进行初始化。之所以发生这种情况是因为每次调用时,mapFunction,即此处的 () => ({}) 都会返回一个新的对象。

然后,fill() 方法创建的 resultB 使用相同的空对象实例进行初始化。不会跳过空项。

4.2 使用 array.map 怎么样?

是不是可以使用 array.map() 方法来实现?我们来试一下:

const length = 3;const init   = 0;const result = Array(length).map(() => init);result; // => [undefined, undefined, undefined]

登录后复制

map() 方法似乎不正常,创建出来的数组不是预期的 [0, 0, 0],而是一个有3个空项的数组。

这是因为 Array(length) 创建了一个有3个空项的数组(也称为稀疏数组),但是 map() 方法会跳过空项。

5. 生成数字范围

你可以使用 Array.from() 生成值范围。例如,下面的 range 函数生成一个数组,从0开始到 end – 1。

function range(end) {    return Array.from({ length: end }, (_, index) => index);}range(4); // => [0, 1, 2, 3]

登录后复制

在 range() 函数中,Array.from() 提供了类似数组的 {length:end} ,以及一个简单地返回当前索引的 map 函数 。这样你就可以生成值范围。

6.数组去重

由于 Array.from() 的入参是可迭代对象,因而我们可以利用其与 Set 结合来实现快速从数组中删除重复项。

function unique(array) {  return Array.from(new Set(array));}unique([1, 1, 2, 3, 3]); // => [1, 2, 3]

登录后复制

首先,new Set(array) 创建了一个包含数组的集合,Set 集合会删除重复项。

因为 Set 集合是可迭代的,所以可以使用 Array.from() 将其转换为一个新的数组。

这样,我们就实现了数组去重。

7.结论

Array.from() 方法接受类数组对象以及可迭代对象,它可以接受一个 map 函数,并且,这个 map 函数不会跳过值为 undefined 的数值项。这些特性给 Array.from() 提供了很多可能。

如上所述,你可以轻松的将类数组对象转换为数组,克隆一个数组,使用初始化填充数组,生成一个范围,实现数组去重。

实际上,Array.from() 是非常好的设计,灵活的配置,允许很多集合转换。

英文原文地址:https://dmitripavlutin.com/javascript-array-from-applications/

本文来自 js教程 栏目,欢迎学习!

以上就是五个超好用的Array.from()用途(详解)的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2729552.html

(0)
上一篇 2025年3月8日 00:07:53
下一篇 2025年2月26日 06:54:56

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 浅谈前端的正则表达式

    1. 概览 在 JavaScript 中,使用 // 即可创建一个正则表达式对象,当然也可以使用 new RegExp() 常用的跟正则相关的方法有 match、test 和 replace。 其中 match,replace 都是字符串上…

    2025年3月8日 编程技术
    200
  • 浅谈javascript执行机制

    js是单线程的,为什么可以执行异步操作呢? 这归结与浏览器(js的宿主环境)通过某种方式使得js具备了异步的属性。 区分进程和线程: 进程:正在运行中的应用程序。每个进程都自己独立的内存空间。例如:打开的浏览器就是一个进程。 立即学习“Ja…

    2025年3月8日
    200
  • canvas如何实现七巧板图案和粒子时钟效果?(代码示例)

    canvas如何实现七巧板图案和粒子时钟效果?下面本篇文章就来给大家介绍一下。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 canvas实现七巧板 var rangram = [ { p: [{ x: 0, y: 0 }…

    2025年3月8日
    200
  • 浅谈JavaScript对象属性的特性和defineProperty方法

    对象是无序属性的集合,而这些属性在创建是都带有一些特征值(可以理解为属性的属性,天生自带的),这些特征值是为了实现JavaScript引擎用的,因此JavaScript不能直接访问。 JavaScript通过这些特征值来定义属性的行为(属性…

    2025年3月8日
    200
  • JavaScript如何实现动态轮播图效果?(代码示例)

    本篇文章给大家带来的内容是javascript如何实现动态轮播图效果?(代码示例)。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 功能描述: 1.鼠标经过 左右侧箭头显示,鼠标离开 箭头隐藏 2.动态添加底部小圆圈并绑定…

    2025年3月8日 编程技术
    200
  • JavaScript仿淘宝回到顶部效果(代码示例)

    本篇文章给大家带来的内容是javascript仿淘宝回到顶部效果(代码示例)。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 需求:当滚动条到一定位置时侧边栏固定在某个位置,再往下滑动到某一位置时显示回到顶部按钮。点击按钮…

    2025年3月8日
    200
  • 详解DOM事件流的三个阶段

    事件发生时会在元素节点之间按照特定的顺序传播,这个传播过程即dom事件流。 DOM事件流分为三个阶段,分别为: 捕获阶段:事件从Document节点自上而下向目标节点传播的阶段; 目标阶段:真正的目标节点正在处理事件的阶段; 冒泡阶段:事件…

    2025年3月8日 编程技术
    200
  • 浅谈JavaScript之DOM核心操作

    文档对象模型(document object model,简称dom),是w3c组织推荐的处理可扩展标记语言(html或xml)的标准编程接口。 W3C已经定义了一系列DOM接口,通过这些DOM接口可以改变网页的内容、结构和样式。 1、对于…

    2025年3月8日 编程技术
    200
  • 鲜为人知的 JSON.stringify 用法

    js 中有许多常见的函数,我们可能每天都在使用它们,但是却不知道它们的一些额外功能。json.stringify 就是这样的一个函数,今天就来看下它的特殊用法。 基础 JSON.stringify 方法接收一个变量,并将它转换成 JSON …

    2025年3月8日
    200
  • 浅谈ES6中的字符串(代码示例)

    1、多了两个新方法 (1)startWith:判断一个字符串是否以某个字段开头 let str=’asdfgh’;console.log(str.startsWith(‘a’));//true 登录后复制 应用: let str=’http…

    2025年3月8日
    200

发表回复

登录后才能评论