欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue中data的基礎(chǔ)匯總

 更新時間:2022年08月04日 14:17:30   作者:Celester_best  
這篇文章主要介紹了vue如何重置data、組件中的data為什么是一個函數(shù)、為什么new Vue里的data可以是一個對象,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

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ù)的解決方案

    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及格式問題詳解

    這篇文章主要介紹了使用vue插件axios傳數(shù)據(jù)的Content-Type以及格式問題,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-09-09
  • Vue?數(shù)據(jù)綁定事件綁定樣式綁定語法示例

    Vue?數(shù)據(jù)綁定事件綁定樣式綁定語法示例

    這篇文章主要為大家介紹了Vue?數(shù)據(jù)綁定事件綁定樣式綁定語法示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • vue3+vite配置多頁面的示例代碼

    vue3+vite配置多頁面的示例代碼

    通過配置多頁面應(yīng)用,從而將給子模塊依賴分隔開各自加載,可以減少初始資源的請求,加快頁面的訪問速度,這篇文章主要介紹了vue3+vite配置多頁面的詳細(xì)過程,需要的朋友可以參考下
    2023-06-06
  • vue.js 動態(tài)組件詳解

    vue.js 動態(tài)組件詳解

    這篇文章主要介紹了vue.js 動態(tài)組件詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-09-09
  • Vue項目中使用flow做類型檢測的方法

    Vue項目中使用flow做類型檢測的方法

    這篇文章主要介紹了Vue項目中使用flow做類型檢測的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • Vue鼠標(biāo)滾輪滾動切換路由效果的實現(xiàn)方法

    Vue鼠標(biāo)滾輪滾動切換路由效果的實現(xiàn)方法

    這篇文章主要介紹了Vue鼠標(biāo)滾輪滾動切換路由效果的實現(xiàn)方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-08-08
  • 解決vue路由name同名,路由重復(fù)的問題

    解決vue路由name同名,路由重復(fù)的問題

    這篇文章主要介紹了解決vue路由name同名,路由重復(fù)的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • Vue組件更新數(shù)據(jù)v-model不生效的解決

    Vue組件更新數(shù)據(jù)v-model不生效的解決

    這篇文章主要介紹了Vue組件更新數(shù)據(jù)v-model不生效的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue+Echart柱狀圖實現(xiàn)疫情數(shù)據(jù)統(tǒng)計

    Vue+Echart柱狀圖實現(xiàn)疫情數(shù)據(jù)統(tǒng)計

    這篇文章主要介紹了在Vue nuxt項目中,如何使用Echart(百度圖表)柱狀圖來實現(xiàn)疫情數(shù)據(jù)統(tǒng)計,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2021-12-12

最新評論