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