JS解决 Array.fill()参数为对象指向同一个引用地址的问题

JS中,数组的fill()方法可以用来将一个固定值填充到数组中的每一个元素上。但是当传递的参数为对象时,会出现指向同一个引用地址的问题。因此,为了解决这个问题,我们可以采取以下几种方案。

方案一:使用 ES6 中的 Array.from() 方法

在 ES6 中,Array.from() 方法可以将任何可迭代对象转换为一个数组。因此,我们可以先使用该方法生成一个全是空对象的数组,然后再使用map()方法将每一个空对象填充为我们想要的数据。

const arr = Array.from({ length: 5 }, () => ({})); 
arr.map(item => {
  Object.assign(item, {name: '张三', age: 18});
});

使用以上方法,每个数据对象都将是不同的,它们互不影响。

方案二:使用 JSON 序列化和反序列化

我们可以使用 JSON 序列化和反序列化的方法来实现拷贝对象,从而达到解决相同引用地址的问题。

const obj = { name: '张三', age: 18 };
const arr = new Array(5).fill(JSON.parse(JSON.stringify(obj)));

以上方法先将对象转成字符串再反序列化成对象,这样就会生成不同的对象实例,从而解决了相同引用地址的问题。

总结

以上就是两种解决Array.fill()参数为对象指向同一个引用地址的问题的方法。无论是使用Array.from()方法还是使用 JSON 的序列化和反序列化方法,都可以有效地解决这个问题,具体使用哪种方法视场景而定。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:JS解决 Array.fill()参数为对象指向同一个引用地址的问题 - Python技术站

(0)
上一篇 2023年6月8日
下一篇 2023年6月8日

相关文章

  • Nodejs学习笔记之入门篇

    Node.js学习笔记之入门篇攻略 简介 本篇文章主要针对初学者,介绍Node.js的入门知识和基本概念,包括Node.js的使用场景,安装及配置,模块和包管理机制等,旨在帮助读者快速了解Node.js的基础知识,为进一步学习打下基础。 使用场景 Node.js是一种JavaScript运行环境,具有事件驱动、非阻塞I/O等特性,广泛应用于Web应用开发、后…

    node js 2023年6月8日
    00
  • 详解JavaScript 为什么要有 Symbol 类型?

    下面是详解“详解JavaScript 为什么要有 Symbol 类型?”的完整攻略。 一、为什么要有 Symbol 类型? 在 JavaScript 中,对象的属性名通常是字符串类型的。当我们定义两个同名属性时,后一个属性会覆盖前一个属性。但是,有些场景需要我们定义一些唯一的属性名,避免重复。这时,Symbol 类型就可以派上用场了。Symbol 类型是一种…

    node js 2023年6月8日
    00
  • Lua协同程序coroutine的简介及优缺点

    Lua中的协同程序coroutine是一种特殊的线程,它允许您在相同进程中的不同代码段之间切换执行。与操作系统线程相比,coroutine更加轻量级,且由于没有线程间的切换和锁竞争开销,所以使用coroutine可以有效提高性能。 如何创建一个coroutine 在Lua中,使用函数coroutine.create()可以创建一个coroutine对象,例如…

    node js 2023年6月8日
    00
  • node.js中的emitter.emit方法使用说明

    我们来详细讲解一下”node.js中的emitter.emit方法使用说明”的完整攻略。 什么是EventEmitter EventEmitter是Node.js的一个重要模块,用来实现事件的订阅和发布。它是实现事件驱动编程的基础,同时它也是Node.js中许多API的基础。 EventEmitter是一个构造函数,在使用它之前需要通过require(‘ev…

    node js 2023年6月8日
    00
  • JavaScript运行机制之事件循环(Event Loop)详解

    JavaScript运行机制之事件循环(Event Loop)详解 前言 JavaScript是一门具有单线程执行机制的脚本语言,这意味着它一次只能执行一个任务,不能同时进行多个任务的处理。然而,在进行异步编程时,为了避免出现阻塞,我们经常会使用回调函数。那么,浏览器是如何处理这些异步任务的呢?答案是事件循环机制。 什么是事件循环? 事件循环(Event L…

    node js 2023年6月8日
    00
  • 一文详解node.js有哪些全局对象呢

    一、node.js有哪些全局对象 在Node.js中,有些对象可以在代码的任何地方都使用,这些对象被称为全局对象。这些全局对象可以通过require()函数来引用,以下是Node.js中常用的全局对象: __dirname:表示当前执行脚本所在的目录的绝对路径。 __filename:表示当前执行脚本的文件名。 exports:表示模块的导出对象,如果想要在…

    node js 2023年6月8日
    00
  • Node.js中安全调用系统命令的方法(避免注入安全漏洞)

    在Node.js中安全调用系统命令是非常重要的,避免注入安全漏洞。以下是完整攻略: 使用child_process模块 Node.js提供了child_process模块,专门用于创建子进程。我们可以使用它来安全调用系统命令。 1. 使用exec函数 exec函数可以在一个Shell中执行指定的命令,并缓存执行结果。但是它有一些安全漏洞,例如攻击者可能会使用…

    node js 2023年6月8日
    00
  • Node.js配合node-http-proxy解决本地开发ajax跨域问题

    Node.js是JavaScript运行时环境,可以编写后端服务。对于前端开发中的ajax跨域问题,可以使用Node.js配合node-http-proxy来解决。 node-http-proxy是Node.js的一个HTTP代理服务器模块,它可以将请求代理到其他服务器上,并处理响应数据。通过配置代理规则,使得前端开发时可以访问后端接口,而无需担心跨域问题。…

    node js 2023年6月8日
    00
合作推广
合作推广
分享本页
返回顶部