当前位置:网站首页 > Vue.js开发 > 正文

js深拷贝数组(js深拷贝数组的三种实现方式)



我们知道在JS中对象和数组的操作方式是不一样的,但是我们可以通过封装,给对象加一层包装器,让它可以和数组拥有同样的使用方式。我们主要借助、、、。

Object.keys

看一下MDN上的解释

Object.keys() 方法会返回一个由一个给定对象的自身可枚举属性组成的数组,数组中属性名的排列顺序和正常循环遍历该对象时返回的顺序一致。

也就是可以获取对象的所有属性名,并生成一个数组。

Object.values

看一下MDN上的解释:

Object.values()方法返回一个给定对象自身的所有可枚举属性值的数组,值的顺序与使用for...in循环的顺序相同 ( 区别在于 for-in 循环枚举原型链中的属性 )。

返回一个数组,元素是对象上找到的可枚举属性值。

Object.entries

看一下MDN上的解释:

Object.entries()方法返回一个给定对象自身可枚举属性的键值对数组,其排列与使用 for...in 循环遍历该对象时返回的顺序一致(区别在于 for-in 循环还会枚举原型链中的属性)。

返回一个数组,元素是由属性名和属性值组成的数组。

Proxy

是JS最新的对象代理方式,用于创建一个对象的代理,从而实现基本操作的拦截和自定义(如属性查找、赋值、枚举、函数调用等)。使用可以封装对象的原始操作,在执行对象操作的时候,会经过的处理,这样我们就可以实现数组操作命令。

基础 get 示例

以上示例的中,当对象中不存在属性名时,默认返回值为37

无操作转发代理

使用包装原生对象生成一个代理对象p,对代理对象的操作会转发到原生对象上。

我们要实现一下几个函数:、、、、、、、、、。

forEach

数组中的函数定义:数组中的需要传入一个函数,函数的第一个参数是当前操作的元素值,第二个参数是当前操作的元素索引,第三个参数是正在操作的对象。对于对象,我们将参数定为:currentValue、key、target。我们可以使用来遍历对象。

这里需要和参数,我们通过函数封装一下

这样我们就可以使用以下方式调用:

通过封装:

以上方式当然是不行的,我们主要看最后一句,其执行方式和数组的完全相同,我们在调用封装的对象时,获取数据时,会调用函数,第一个参数为原生对象,第二个参数为属性名-,在这里就要修改我们的函数了。 首先的参数是一个函数,因此我们代理对象的返回值需要接收一个函数作为参数,因此修改如下:

因此完成代码为:

我们应该把以上代码封装为模块,方便对外使用:

以上是的实现和封装,其他函数的实现方式类似。

全部源码如下:

本文由 mdnice 多平台发布

到此这篇js深拷贝数组(js深拷贝数组的三种实现方式)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!

版权声明


相关文章:

  • jsj是什么的缩写(js是什么意思的缩写)2025-07-04 13:00:05
  • jsy是哪个明星(jsy是哪位明星)2025-07-04 13:00:05
  • vue3插槽(vue3插槽案例)2025-07-04 13:00:05
  • redhat操作系统安装(redhat7.3系统安装教程)2025-07-04 13:00:05
  • vmware密钥多少钱(vmware12.0密钥)2025-07-04 13:00:05
  • vue 路由安装(vue路由安装命令)2025-07-04 13:00:05
  • map怎么转json字符串(map转json字符串 转义符)2025-07-04 13:00:05
  • vue2插槽(vue2插槽传参)2025-07-04 13:00:05
  • vue2关闭严格模式(vuex 严格模式)2025-07-04 13:00:05
  • vue钩子函数有几种(vue2钩子函数)2025-07-04 13:00:05
  • 全屏图片