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


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

    1
    2
    3
    4
    5
    6
    7
    8
    var json = { top: '400px', '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’, ‘500px’, height: ‘300px’ };),在循环外面定义一个对象,用于保存分离的json对象。

    object

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

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

    object

    结果:
    result

  • 相关阅读:
    POJ 1269 Intersecting Lines
    POJ 3304 Segments
    BZOJ 4591 超能粒子炮·改
    POJ 2318 TOYS/POJ 2398 Toy Storage
    BZOJ 1044 木棍分割
    BZOJ 2836 魔法树
    BZOJ 3176 Sort
    BZOJ 1668 馅饼里的财富
    Flood-it!
    Eight
  • 原文地址:https://www.cnblogs.com/langzianan/p/11423614.html
Copyright © 2020-2023  润新知