文章详情页
javascript - angular循环的时候取到的值是最后一个值
浏览:229日期:2023-02-16 15:36:28
问题描述
代码如下:
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出来的是不同的。
问题解答
回答1:val 是对象,相当于一个指针,因此每次 push 进去的都是同一个对象
由于不知道你的 val 还有其他哪些属性和作用,这里仅提供一个替换方案:push({...val, userDtoName: data})
用到了 ES6 的 ... spread 运算符。
回答2:如果没有看错的话,你便利的是val.userAssetList,却把val放进lay,每次都是一样的啊,都是执行lay.push(val)
标签:
JavaScript
相关文章:
1. docker start -a dockername 老是卡住,什么情况?2. 在windows下安装docker Toolbox 启动Docker Quickstart Terminal 失败!3. golang - 用IDE看docker源码时的小问题4. Android Chrome忽略-webkit-text-size-adjust:none属性。缩小文字时,文字会被缩放5. css3 - canvas画对角线很模糊6. python - pip安装任何包都出现问题: Cannot unpack file /tmp/pip-KzJgHD-unpack/simple7. javascript - node.js后台设置token过期时间出现的问题8. Java的HttpURLConnecction的getInputStream是否需要close?9. java - bin目录有什么特殊含义吗?为什么可执行文件都放在bin目录?10. javascript - 关于向java后台上传base64位字符串的图片数据,求助
排行榜

网公网安备