vue中data的基礎(chǔ)匯總
vue中如何重置data
重置data需要了解3個小知識點
(1)this.$data獲取組件當(dāng)前狀態(tài)的data對象
(2)this.$options.data獲取組件初始狀態(tài)的data對象
(3)Object.assign()方法用于將所有可美劇屬性的值從一個或者多個源對象復(fù)制到目標(biāo)對象,并返回目標(biāo)對象。
Object.assign(target,source1,source2,....sourceN)方法中可以傳遞多個參數(shù),第一個參數(shù)是目標(biāo)對象,后面的是源對象,源對象可以有一個或者多個。
Object.assign()方法還可以用來合并對象。合并時目標(biāo)對象會改變,如果遇到相同屬性時,后面的屬性值就會覆蓋前面的屬性值。
給予以上小知識點,我們可以很容易的重置vue中的data
Object.assign(this.$data, this.$options.data.call(this));
示例:
<template> <div> <p>Vue中data相關(guān)的知識點</p> <button @click="addElement">添加元素</button> <div v-for="item in dataList" :key="item">{{ item }}</div> <div> <button @click="resetData">重置</button> </div> </div> </template> <script> export default { name: "DataTest", data() { return { dataList: [], }; }, methods: { addElement() { this.dataList.push(this.dataList.length + 1); }, resetData() { Object.assign(this.$data, this.$options.data.call(this)); }, }, }; </script>
點擊添加按鈕,添加元素
點擊重置按鈕:
可以看到dataList變成一個長度為0的數(shù)組,所以data被重置了。
組件中的data為什么是一個函數(shù)
vue組件可以復(fù)用,如果data是一個對象,作用域沒有分開,組件之間的data就會相互影響。是一個函數(shù)的話每個示例都可以維護一份被返回對象的獨立拷貝,組件之間的data屬性值就不會相互影響。
如果組件中的data是一個對象:
function VueComponent() {} VueComponent.prototype.data = { count: 0, }; const A = new VueComponent(); const B = new VueComponent(); console.log(" A count: ", A.data.count); console.log(" B count: ", B.data.count); A.data.count = 10; console.log("修改A組件的count后 A count: ", A.data.count); console.log("修改A組件的count后 B count: ", B.data.count);
可以看到修改A組件中data的count值之后,B組件中data的count值也發(fā)生了變化。
如果組件中的data是一個函數(shù):
function VueComponent() { this.data = this.data(); } VueComponent.prototype.data = function () { return { count: 0, }; }; const A = new VueComponent(); const B = new VueComponent(); console.log(" A count: ", A.data.count); console.log(" B count: ", B.data.count); A.data.count = 10; console.log("修改A組件的count后 A count: ", A.data.count); console.log("修改A組件的count后 B count: ", B.data.count);
可以看到修改A組件中data的count值之后,B組件中data的count值并沒有變化,所以組件之間的數(shù)據(jù)不會相互影響。
為什么new Vue里的data可以是一個對象
vue實例中的data既可以是對象也可以是函數(shù),為什么vue實例中的date可以是對象呢?
因為Vue開發(fā)的應(yīng)用一般為單頁面應(yīng)用,通常情況下只會new一個Vue對象,所以不會存在多個實例對象之間數(shù)據(jù)相互影響的情況。
到此這篇關(guān)于vue中data的基礎(chǔ)匯總的文章就介紹到這了,更多相關(guān)vue data內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue單頁面應(yīng)用保證F5強刷不清空數(shù)據(jù)的解決方案
最近小編遇到這樣的問題當(dāng)vue單頁面按F5強刷,數(shù)據(jù)就恢復(fù)初始了,這怎么辦呢?下面小編給大家?guī)砹薞ue單頁面應(yīng)用保證F5強刷不清空數(shù)據(jù)的解決方案,感興趣的朋友一起看看吧2018-01-01使用vue插件axios傳數(shù)據(jù)的Content-Type及格式問題詳解
這篇文章主要介紹了使用vue插件axios傳數(shù)據(jù)的Content-Type以及格式問題,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-09-09Vue鼠標(biāo)滾輪滾動切換路由效果的實現(xiàn)方法
這篇文章主要介紹了Vue鼠標(biāo)滾輪滾動切換路由效果的實現(xiàn)方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-08-08Vue組件更新數(shù)據(jù)v-model不生效的解決
這篇文章主要介紹了Vue組件更新數(shù)據(jù)v-model不生效的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04Vue+Echart柱狀圖實現(xiàn)疫情數(shù)據(jù)統(tǒng)計
這篇文章主要介紹了在Vue nuxt項目中,如何使用Echart(百度圖表)柱狀圖來實現(xiàn)疫情數(shù)據(jù)統(tǒng)計,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2021-12-12