JS 原生 push对象到数组中遇到的问题

Posted 熊大黑吖

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS 原生 push对象到数组中遇到的问题相关的知识,希望对你有一定的参考价值。

在做小程序开发时,需要将一个对象push到数组中,第一次写法是

 for(var j in that.data.goods ){//遍历商品信息 获取商品id
        // console.log(that.data.goods[j].id)
      for(var h in that.data.cart.list){//遍历缓存中购物车列表,获取下标
          if(j==h){
           // var goods_id_list ={‘id‘:‘‘,‘num‘:‘‘};//定义一个接受对象
            console.log(that.data.goods[j].id)//获取了所选商品的id值
            console.log(that.data.cart.list[h])//获取了所选商品的数量
            that.data.cartGoods=that.data.goods[j].id;
           that.data.cartGoods = that.data.cart.list[h];
            // var aa = that.data.cartGoods
             goods.push(that.data.cartGoods);//添加数组信息
          }
      }

这样输出的结果你数组元素都是最后一个对象。因为tmp声明在for循环之外,当listData数组push这个tmp对象时,一直是同一个对象,而并不是将对象的数据压入,只是在listData数组建立了一个对象的引用关系。故随着for的i值改变,tmp对象内部的内容也跟着改变,而listData压入的对象却始终是tmp这个对象(tmp生命周期不受for循环影响)。所以最终console.log(listData)出来的对象数组里面的元素都是一样的数据。简言之:就是tmp对象的数据再变,但是listData压入的tmp却是不变的。

需要在里面定义一个接受数组

    for(var j in that.data.goods ){//遍历商品信息 获取商品id
        // console.log(that.data.goods[j].id)
      for(var h in that.data.cart.list){//遍历缓存中购物车列表,获取下标
          if(j==h){
           var goods_id_list ={‘id‘:‘‘,‘num‘:‘‘};//定义一个接受对象
            console.log(that.data.goods[j].id)//获取了所选商品的id值
            console.log(that.data.cart.list[h])//获取了所选商品的数量
            goods_id_list.id=that.data.goods[j].id;
            goods_id_list.num = that.data.cart.list[h];
            // var aa = that.data.cartGoods
             goods.push(goods_id_list);//添加数组信息
          }
      }
    }

 

以上是关于JS 原生 push对象到数组中遇到的问题的主要内容,如果未能解决你的问题,请参考以下文章

怎么将json对象添加进json数组中

原生JS数组对象去重方法

原生JS数组方法实现(一)————push()unshift()pop()和shift()

数组和对象都有哪些原生方法?

原生JS常用代码汇总

怎么把json字符串转成数组对象