JS:数组中push对象,覆盖问题

发现将对象push进数组,后面的值会覆盖前面的值,最后输出的都是最后一次的值。其实这一切都是引用数据类型惹的祸。
如果你也有类似问题,可以继续看下去哦。
下面代码模拟:
将json对象的每个键值对,单独搞成对象,再赋值给数组,最后输出数组。结果数组应该是有三个对象。(for-in用于对象遍历)

 
1
2
3
4
5
6
7
8
var json = { top : '400px' , width: '500px' , height: '300px' };
var data = {};//在外面定义对象
var datas = [];
for ( key in json) {
     data. name = key ;
     datas.push(data);
}
console.log(datas)

输出结果:
result

原因:
我们遍历json对象时(var json = { top: ‘400px’, width: ‘500px’, height: ‘300px’ };),在循环外面定义一个对象,用于保存分离的json对象。

object

解决方法:
每次循环的时候,新建一个对象

 
1
2
3
4
5
6
7
8
var json = { top : '400px' , width: '500px' , height: '300px' };
var datas = [];
for ( key in json) {
     var data = {};//每次循环的时候,新建对象
     data. name = key ;
     datas.push(data);
}
console.log(datas)

object

结果:
result

转载于:https://www.cnblogs.com/langzianan/p/11423614.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值