文章詳情頁
javascript - angular循環的時候取到的值是最后一個值
瀏覽:106日期: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 for Mac 創建的dnsmasq容器連不上/不工作的問題2. html5 - 為什么有的時候要在網頁中加偽元素3. html - Python2 BeautifulSoup 提取網頁中的表格數據及連接4. python - PyCharm里的一個文件不小心忽略了wx包5. html5 - css 這種六邊形的邊框怎么畫?6. html5 - javascript讀取自定義屬性的值,有的能夠取到,有的取不到怎么回事??7. 小白學python的問題 關于%d和%s的區別8. win10 Apache24+PHP8.0,Apache不能正常加載php.ini。9. javascript - 關于微信掃一掃的技術問題10. html5 - 請問利用font-face定義的字體怎么在canvas里應用?
排行榜
