在平常開發中,咱們用的最多的就是 綁定數據css
<div v-for="item in data" :key="item.id">
<!-- 內容 -->
</div>
複製代碼
若是你有ng的開發經驗,假設 data 你要更新數據了html
this.data=res.data;vue
可是這在vue中 並不會起到做用,DOM並無觸發變化。node
vue不是已經實現的實時數據雙向綁定,那麼model層發生了變化以後,爲何view層沒有更新呢???webpack
看官網 這裏才發現 深刻響應式原理 列表渲染web
數組檢測更細變異的方法面試
注意事項數組
因爲 JavaScript 的限制,Vue 不能檢測如下變更的數組:bash
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,快速升職加薪,走上人生巔峯。