广告
返回顶部
首页 > 资讯 > 前端开发 > node.js >javascript拷贝数组的技巧
  • 285
分享到

javascript拷贝数组的技巧

2024-04-02 19:04:59 285人浏览 泡泡鱼
摘要

这篇文章主要介绍“javascript拷贝数组的技巧”,在日常操作中,相信很多人在javascript拷贝数组的技巧问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”javasc

这篇文章主要介绍“javascript拷贝数组的技巧”,在日常操作中,相信很多人在javascript拷贝数组的技巧问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”javascript拷贝数组的技巧”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

技巧 1 - 使用`Array.slice`方法

const numbers = [1, 2, 3, 4, 5]  const copy = numbers.slice() copy.push(6) // 添加新项以证明不会修改原始数组  console.log(copy) console.log(numbers)  // 输出 // [1, 2, 3, 4, 5, 6] // [1, 2, 3, 4, 5]

技巧 2 - 使用`Array.map`方法

const numbers = [1, 2, 3, 4, 5]  const copy = numbers.map( num => num ) copy.push(6) // 添加新项以证明不会修改原始数组  console.log(copy); console.log(numbers);  // 输出 // [1, 2, 3, 4, 5, 6] // [1, 2, 3, 4, 5]

技巧 3 - 使用`Array.from `方法

const numbers = [1, 2, 3, 4, 5];  const copy = Array.from(new Set(numbers)); copy.push(6); // 添加新项以证明不会修改原始数组  console.log(copy); console.log(numbers);  // 输出 // [1, 2, 3, 4, 5, 6] // [1, 2, 3, 4, 5]

技巧 4 - 使用展开操作符

const numbers = [1, 2, 3, 4, 5];  const copy = [...numbers]; copy.push(6); // 添加新项以证明不会修改原始数组  console.log(copy); console.log(numbers);  // 输出  // [1, 2, 3, 4, 5, 6] // [1, 2, 3, 4, 5]

技巧 5 - 使用 `Array.of` 方法和展开操作符

const numbers = [1, 2, 3, 4, 5];  const copy = Array.of(...numbers); copy.push(6); // 添加新项以证明不会修改原始数组  console.log(copy); console.log(numbers);  // 输出  // [1, 2, 3, 4, 5, 6] // [1, 2, 3, 4, 5]

Array.of() 方法创建一个具有可变数量参数的新数组实例,而不考虑参数的数量或类型。Array.of() 和 Array  构造函数之间的区别在于处理整数参数:Array.of(7) 创建一个具有单个元素 7 的数组,而 Array(7)  创建一个长度为7的空数组(注意:这是指一个有7个空位(empty)的数组,而不是由7个undefined组成的数组)。

Array.of(7); // [7]  Array.of(1, 2, 3); // [1, 2, 3]  Array(7); // [ , , , , , , ] Array(1, 2, 3); // [1, 2, 3]

技巧 6 - 使用 Array 构造函数和展开操作符

const numbers = [1, 2, 3, 4, 5];  const copy = new Array(...numbers); copy.push(6); // 添加新项以证明不会修改原始数组  console.log(copy); console.log(numbers);  // 输出  // [1, 2, 3, 4, 5, 6] // [1, 2, 3, 4, 5]

技巧 7 - 使用解构

const numbers = [1, 2, 3, 4, 5];  const [...copy] = numbers; copy.push(6); // 添加新项以证明不会修改原始数组  console.log(copy); console.log(numbers);  // 输出 // [1, 2, 3, 4, 5, 6] // [1, 2, 3, 4, 5]

技巧 8 - 使用 Array.concat 方法

const numbers = [1, 2, 3, 4, 5];  const copy = numbers.concat(); copy.push(6); // 添加新项以证明不会修改原始数组  console.log(copy); console.log(numbers);  // 输出 // [1, 2, 3, 4, 5, 6] // [1, 2, 3, 4, 5]

技巧 9 - 使用 `Array.push` 方法和展开操作符

const numbers = [1, 2, 3, 4, 5];  let copy = []; copy.push(...numbers); copy.push(6); // 添加新项以证明不会修改原始数组  console.log(copy); console.log(numbers);  // 输出 // [1, 2, 3, 4, 5, 6] // [1, 2, 3, 4, 5]

技巧 10 - 使用 `Array.unshift ` 方法和展开操作符

const numbers = [1, 2, 3, 4, 5];  let copy = []; copy.unshift(...numbers); copy.push(6); // 添加新项以证明不会修改原始数组  console.log(copy); console.log(numbers);  // 输出 // [1, 2, 3, 4, 5, 6] // [1, 2, 3, 4, 5]

技巧 11 - 使用 `Array.forEach` 方法和展开操作符

const numbers = [1, 2, 3, 4, 5];  let copy = []; numbers.forEach((value) => copy.push(value)); copy.push(6); // 添加新项以证明不会修改原始数组  console.log(copy); console.log(numbers);  // 输出 // [1, 2, 3, 4, 5, 6] // [1, 2, 3, 4, 5]

技巧 12 - 使用 `for` 循环

const numbers = [1, 2, 3, 4, 5];let copy = [];for (let i = 0; i < numbers.length; i++) {  copy.push(numbers[i]); } copy.push(6); // 添加新项以证明不会修改原始数组  console.log(copy); console.log(numbers);  // 输出 // [1, 2, 3, 4, 5, 6] // [1, 2, 3, 4, 5]

技巧 13 - 使用 `Array.reduce` 方法

这个做法是可行,但比较多余,少用

const numbers = [1, 2, 3, 4, 5];  const copy = numbers.reduce((acc, x) => { acc.push(x); return acc; }, []); copy.push(6); // 添加新项以证明不会修改原始数组  console.log(copy); console.log(numbers);  // 输出 // [1, 2, 3, 4, 5, 6] // [1, 2, 3, 4, 5]

技巧 14 - 使用古老的 `apply` 方法

const numbers = [1, 2, 3, 4, 5];

let copy = []; Array.prototype.push.apply(copy, numbers); copy.push(6); // 添加新项以证明不会修改原始数组  console.log(copy); console.log(numbers);  // 输出 // [1, 2, 3, 4, 5, 6] // [1, 2, 3, 4, 5]

代码部署后可能存在的BUG没法实时知道,事后为了解决这些BUG,花了大量的时间进行log 调试,这边顺便给大家推荐一个好用的BUG监控工具  Fundebug。

原文:https://twitter.com/protic_milos

总结

请注意,上面这些方法执行的是浅拷贝,就是数组是元素是对象的时候,咱们更改对象的值,另一个也会跟着变,就能技巧4来说,如果咱们的数组元素是对象,如下所示:

const authors = [  { name: '前端小智', age: 25 },   { name: '王大冶', age: 30 },  ]  const copy = [...authors ] copy[0].name = '被更改过的前端小智'  console.log(copy) console.log(authors)

输出

javascript拷贝数组的技巧

到此,关于“javascript拷贝数组的技巧”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: javascript拷贝数组的技巧

本文链接: https://www.lsjlt.com/news/80722.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • javascript拷贝数组的技巧
    这篇文章主要介绍“javascript拷贝数组的技巧”,在日常操作中,相信很多人在javascript拷贝数组的技巧问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”javasc...
    99+
    2022-10-19
  • JS数组拷贝技巧有哪些
    这篇文章主要为大家展示了“JS数组拷贝技巧有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JS数组拷贝技巧有哪些”这篇文章吧。   技巧 1 - 使用Ar...
    99+
    2022-10-19
  • 在JavaScript 中14个拷贝数组的技巧分别是怎样的
    在JavaScript 中14个拷贝数组的技巧分别是怎样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。数组拷贝经常被误解,但这并不是因为拷贝...
    99+
    2022-10-19
  • Golang切片和数组拷贝详解(浅拷贝和深拷贝)
    目录golang切片和数组拷贝基础什么是浅拷贝和深拷贝?golang数组和切片的区别Golang中的值传递和引用传递golang数组拷贝数组和切片拷贝总结golang切片和数组拷贝 ...
    99+
    2023-05-17
    Golang切片和数组拷贝 golang切片拷贝 golang数组拷贝
  • javascript中怎么深拷贝与浅拷贝二维数组和对象
    javascript中怎么深拷贝与浅拷贝二维数组和对象,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1.浅拷贝: 将原对象或原...
    99+
    2022-10-19
  • javascript赋值、浅拷贝、深拷贝的概念
    本篇内容介绍了“javascript赋值、浅拷贝、深拷贝的概念”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成...
    99+
    2022-10-19
  • javaScript深拷贝和浅拷贝的简单介绍
    目录基本数据类型在数据结构当中引用数据类型浅拷贝-深拷贝浅拷贝浅拷贝小结深拷贝结尾源码地址在了解深拷贝和浅拷贝之前,我们先梳理一下: JavaScript中,分为基本数据类型(原始值...
    99+
    2022-11-13
  • js数组直接赋值的问题(js数组的浅拷贝与深拷贝方法)
    1、数组的直接赋值属于数组的浅拷贝,JS存储对象都是存内存地址,所以浅拷贝会导致新数组和旧数组共用同一块内存地址,其中一个数组变化,另一个数组也会相应的变化。 var a =[1,2...
    99+
    2022-11-13
    JS数组直接赋值 js数组浅拷贝 js数组深拷贝 js array直接赋值 js array浅拷贝 js array深拷贝
  • 使用java怎么浅拷贝和深拷贝二维数组
    使用java怎么浅拷贝和深拷贝二维数组?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。常用的java框架有哪些1.SpringMVC,Spring Web MVC...
    99+
    2023-06-14
  • 如何理解JavaScript中的浅拷贝与深拷贝
    本篇文章给大家分享的是有关如何理解JavaScript中的浅拷贝与深拷贝,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 浅拷贝在使用JavaScript对数组进行操作...
    99+
    2023-06-16
  • javascript深拷贝和浅拷贝的区别有哪些
    这篇文章主要介绍“javascript深拷贝和浅拷贝的区别有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“javascript深拷贝和浅拷贝的区别有哪些”文章能...
    99+
    2022-10-19
  • JavaScript中的深拷贝(deep copy)和浅拷贝(shallow copy)
    聚沙成塔·每天进步一点点 ⭐ 专栏简介 前端入门之旅:探索Web开发的奇妙世界 欢迎来到前端入门之旅!感兴趣的可以订阅本专栏哦!这个专栏是为那些对Web开发感兴趣、刚刚踏入前端领域的朋友们量身打造...
    99+
    2023-10-19
    javascript 开发语言 ecmascript
  • JavaScript中的深拷贝和浅拷贝的详细介绍
    这篇文章主要介绍“JavaScript中的深拷贝和浅拷贝的详细介绍”,在日常操作中,相信很多人在JavaScript中的深拷贝和浅拷贝的详细介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,...
    99+
    2022-10-19
  • java如何实现数组的拷贝
    这篇文章主要介绍java如何实现数组的拷贝,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!数组的拷贝 第一种:  把一个数组的值拷贝到另一个数组 public stat...
    99+
    2023-06-27
  • JavaScript中浅拷贝和深拷贝的区别是什么
    本篇文章为大家展示了JavaScript中浅拷贝和深拷贝的区别是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。前言1. 基础数据类型: undefined、bo...
    99+
    2022-10-19
  • 阿里云拷数据库全面掌握云计算数据库的拷贝和迁移技巧
    随着云计算的发展,数据库已经成为企业的重要组成部分,而数据库的拷贝和迁移成为了日常工作中必不可少的操作。本文将详细介绍阿里云的数据库拷贝和迁移功能,包括其原理、优势和使用方法,帮助您更好地掌握这一重要技能。 一、阿里云数据库拷贝和迁移的原理...
    99+
    2023-11-19
    数据库 阿里 技巧
  • Java数组的拷贝方式有哪些
    这篇文章主要介绍了Java数组的拷贝方式有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。深拷贝与浅拷贝的区别假设现在有原数组A以及拷贝后的数组B,若是改变A中的某一个值,...
    99+
    2023-06-29
  • golang数组拷贝的方法有哪些
    在Go语言中,有以下几种方法可以进行数组的拷贝: 使用循环遍历:可以使用for循环将一个数组的元素逐个拷贝到另一个数组中。 fu...
    99+
    2023-10-20
    golang
  • JavaScript中如何使用扩展运算符拷贝数组
    这篇文章将为大家详细讲解有关JavaScript中如何使用扩展运算符拷贝数组,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。拷贝数组const arr = [1, 2...
    99+
    2023-06-05
  • JavaScript深浅拷贝的介绍
    本篇内容介绍了“JavaScript深浅拷贝的介绍”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!了解拷贝背后的过程,避免不必要的错误,Js专...
    99+
    2023-06-07
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作