深度理解vue 關於陣列和物件的更新

weixin_34019929發表於2018-12-31

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

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

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

this.data=res.data;

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

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

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

12577968-852f2ec1848dfbea
vue 關於陣列和物件的更新

陣列檢測更細變異的方法

  • 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>

Vue提供瞭如下的陣列的變異方法,可以觸發檢視更新

push()
pop()
shift()
unshift()
splice() 
sort()
reverse()
//
介紹一個全棧開發交流學習圈,歡迎加入Q群:864305860

瞭解更多
本次給大家推薦一個免費的學習群,裡面概括移動應用網站開發,css,html,webpack,vue node angular以及面試資源等。
對web開發技術感興趣的同學,歡迎加入Q群:864305860,不管你是小白還是大牛我都歡迎,還有大牛整理的一套高效率學習路線和教程與您免費分享,同時每天更新視訊資料。
最後,祝大家早日學有所成,拿到滿意offer,快速升職加薪,走上人生巔峰。

相關文章