angular循环的时候取到的值是最后一个值

代码如下:

angular.forEach(data.body.data.assets,function(val,ind){

                    angular.forEach(val.userAssetList,function(data,index){
                        val.userDtoName = data;
                        // alert(data.userDTO);
                        if(val.assetCount != val.availableCount){
                            lay.push(val);
                        }
                    })
                   })
          最后我的lay数组中userDtoName的值全部都是最后一个data的值。为什么。但是每一个循环中alert出来的是不同的。
阅读 3.3k
2 个回答

val 是对象,相当于一个指针,因此每次 push 进去的都是同一个对象

由于不知道你的 val 还有其他哪些属性和作用,这里仅提供一个替换方案:push({...val, userDtoName: data})

用到了 ES6 的 ... spread 运算符。

如果没有看错的话,你便利的是val.userAssetList,却把val放进lay,每次都是一样的啊,都是执行lay.push(val)

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题