在日常開發中,我們用的最多的就是 繫結資料
<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>
此隨筆乃本人學習工作記錄,如有疑問歡迎在下面評論,轉載請標明出處。
如果對您有幫助請動動滑鼠右下方給我來個贊,您的支援是我最大的動力。