您现在的位置:首页 >> 前端 >> 内容

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

时间:2017/10/7 10:15:00 点击:

  核心提示:今天写运动框架时,发现将对象push进数组,后面的值会覆盖前面的值,最后输出的都是最后一次的值。其实这一切都是引用数据类型惹的祸。如果你也有类似问题,可以继续看下去哦。下面代码模拟:将json对象的每...

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

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)

输出结果:
JS:数组中push对象,覆盖问题

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

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

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

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)

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

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

Tags:JS S数 数组 组中 
作者:网络 来源:simon_dg的博