Vue動態(tài)添加屬性到data的實現(xiàn)
一、場景例子
<body>
<div id="app">
<p v-for="(value,key) in item" :key="key">
{{value}}
</p>
<button @click="addProperty">動態(tài)添加新屬性</button>
</div>
</body>
</html>
<script>
new Vue({
el:'#app',
data:{
item:{
oldProperty:"舊屬性"
}
},
methods: {
addProperty(){
this.item.newProperty = "新屬性";
console.log(this.item);
}
},
})
</script>效果:點擊按鈕后,輸出的結(jié)果中有新添加的新屬性,但是頁面沒有顯示新屬性。

二、原理分析
vue2使用Object.defineProperty實現(xiàn)數(shù)據(jù)響應式;
const obj = {}
Object.defineProperty(obj, 'foo', {
get() {
console.log(`get foo:${val}`);
return val
},
set(newVal) {
if (newVal !== val) {
console.log(`set foo:${newVal}`);
val = newVal
}
}
})
}- 當訪問foo屬性,或者設(shè)置foo值的時候都能觸發(fā)setter與getter;
- 但是為obj添加新屬性的時候,卻無法觸發(fā)事件屬性的攔截
bj.bar = '新屬性'
原因是一開始obj的foo屬性被設(shè)成了響應式數(shù)據(jù),而bar是后面新增的屬性,并沒有通過Object.defineProperty設(shè)置成響應式數(shù)據(jù)
三、解決方案
有三種解決方案:
- Vue.set()
- Object.assign()
- $forcecUpdated()
常用的就是Vue.set(),語法為:Vue.set( target, propertyName/index, value )
<script>
new Vue({
el:'#app',
data:{
item:{
oldProperty:"舊屬性"
}
},
methods: {
addProperty(){
Vue.set(this.item,"newProperty","新屬性")
console.log(this.item);
}
},
})
</script>
到此這篇關(guān)于Vue動態(tài)添加屬性到data的實現(xiàn)的文章就介紹到這了,更多相關(guān)Vue動態(tài)添加屬性內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解vue結(jié)合el-table實現(xiàn)表格小計總計需求(summary-method)
這篇文章主要介紹了vue結(jié)合el-table實現(xiàn)表格小計總計需求(summary-method),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2024-01-01
el-form-item?prop屬性動態(tài)綁定不生效問題及解決
這篇文章主要介紹了el-form-item?prop屬性動態(tài)綁定不生效問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07
基于Vue2x實現(xiàn)響應式自適應輪播組件插件VueSliderShow功能
本文講述的是從開發(fā)一款基于Vue2x的響應式自適應輪播組件插件的一個全過程,包含發(fā)布到npm,構(gòu)建自己的npm包,供下載安裝使用的技巧,非常不錯,具有一定的參考借鑒價值,感興趣的朋友跟隨腳本之家小編一起看看吧2018-05-05

