vue 關於陣列和物件的更新

huangenai發表於2018-10-23

在日常開發中,我們用的最多的就是 繫結資料

<div v-for="item in data" :key="item.id">
<!-- 內容 -->
</div>

如果你有ng的開發經驗,假設 data 你要更新資料了

this.data=res.data;

但是這在vue中 並不會起到作用,DOM並沒有觸發變化。

vue不是已經實現的實時資料雙向繫結,那麼model層發生了變化之後,為什麼view層沒有更新呢???

看官網 這裡才發現 深入響應式原理  列表渲染

 

陣列檢測更細變異的方法

  • push()
  • pop()
  • shift()
  • unshift()
  • splice()
  • sort()
  • reverse()

 

注意事項

由於 JavaScript 的限制,Vue 不能檢測以下變動的陣列:

1.  this.data[index] = res.data;

2.  this.data.length = 0;

 

正確的操作方式

1. Vue.$set(this.data, 1, {name:"huangenai",age:"22"})

2.   vm.items.splice(0)

 

物件

還是由於 JavaScript 的限制,Vue 不能檢測物件屬性的新增或刪除:

<script> 
export default {
      data(){
            return {
                userProfile: {
                    name: `Anika`
                }
                user: {
                   name: "huangenai",
                   age: 12
                }
            }
     },
     mounted() {
           this.$set(this.userProfile, `age`, 27)
           this.user = Object.assign({}, this.user, {
                                     age: 22,
                                     name: "huangenai"
           });
     }
   }
</script>

 

此隨筆乃本人學習工作記錄,如有疑問歡迎在下面評論,轉載請標明出處。

如果對您有幫助請動動滑鼠右下方給我來個贊,您的支援是我最大的動力。

 

相關文章