使用push你必须知道的小细节

本文通过实例演示了JavaScript中数组的push方法特性,特别是当推入的是对象引用时的行为表现,揭示了对象传递的本质。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

相信大家平时开发的过程中,经常需要对数组进行操作,说到对数组的操作,push还是出场率很高的。

今天本人在使用push的过程中,因为对这个方法的理解不够深,导致开发过程中出现了小小的困扰。这里先给大家举个例子:

var obj = {name: 'han'};
var arr = [];
arr.push(obj)
arr.push(obj)
arr.push(obj)
arr.push(obj)
obj.name = 'liu'

在这里,我们往一个空数组 arr 里面添加了三个对象,然后将 obj 对象进行了改动,你们猜数组的变化是怎么样的?有没有收到其影响?

既然都这么问了,想都不用想,肯定发生变化了呗,果然:

// 果然,控制返回的结果是:
[(4) [{…}, {…}, {…}, {…}]
{name: "liu"}
{name: "liu"}
{name: "liu"}
{name: "liu"}]

从这里看出了, push 进去的对象,相当于等于号 ‘=’ 的过程,对于对象,只是复制其指针地址,并不是真正意义上的复制,所以这里多个对象其实是指向同一个地址的。于是乎才产生这种情况。

在这里小小的分享了一些开发过程中的一些坑,和解决他们之后的收获,更多文章请转到此处 点我哦!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值