亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vuex3和Vuex4有哪些區(qū)別

 更新時間:2023年04月20日 10:22:07   作者:shichuan  
本文主要介紹了Vuex3和Vuex4有哪些區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

Vuex 是 Vue.js 的官方狀態(tài)管理庫,用于在 Vue.js 應(yīng)用中管理應(yīng)用狀態(tài)。Vuex 3 是用于 Vue 2 的版本,而 Vuex 4 是用于 Vue 3 的版本。下面是 Vuex 3 和 Vuex 4 在一些重要方面的異同點:

創(chuàng)建 Store 的方式

  • Vuex 3:使用 new Vuex.Store() 創(chuàng)建 store 實例
import Vue from 'vue'
import Vuex from 'vuex'
?
Vue.use(Vuex)
?
const store = new Vuex.Store({
  // 配置項
})
?
export default store
  • Vuex 4:使用 createStore 函數(shù)創(chuàng)建 store 實例
import { createStore } from 'vuex'
?
const store = createStore({
  // 配置項
})
?
export default store

Vuex 4 中使用 createStore 函數(shù)來創(chuàng)建 store 實例,而不是直接在 Vue 實例上掛載。

在組件中使用 Store

  • Vuex 3:使用 this.$store 訪問 store 實例,通過 this.$store.state 訪問狀態(tài),通過 this.$store.commit() 進(jìn)行提交 mutation,通過 this.$store.dispatch() 進(jìn)行分發(fā) action。
export default {
  computed: {
    count() {
      return this.$store.state.count
    }
  },
  methods: {
    increment() {
      this.$store.commit('increment')
    },
    incrementAsync() {
      this.$store.dispatch('incrementAsync')
    }
  }
}
  • Vuex 4:使用 useStore 函數(shù)來獲取 store 實例,通過 store.state 訪問狀態(tài),通過 store.commit() 進(jìn)行提交 mutation,通過 store.dispatch() 進(jìn)行分發(fā) action。
import { useStore } from 'vuex'
?
export default {
  setup() {
    const store = useStore()
    const count = computed(() => store.state.count)
?
    const increment = () => {
      store.commit('increment')
    }
?
    const incrementAsync = () => {
      store.dispatch('incrementAsync')
    }
?
    return {
      count,
      increment,
      incrementAsync
    }
  }
}

雖然 Vuex4 推薦使用更符合 Composition API 風(fēng)格的 useStore() 來獲取 store 實例。但是并沒有移除 this.$store,但是在 <template>Vue2 選項式寫法中還是支持使用 $store 的。

輔助函數(shù)的用法

  • Vuex 3:使用 mapState、mapGetters、mapMutationsmapActions 輔助函數(shù)來進(jìn)行映射,簡化在組件中對 store 的訪問。
import { mapState, mapGetters, mapMutations, mapActions } from 'vuex'
?
export default {
  computed: {
    ...mapState(['count']),
    ...mapGetters(['doubleCount']),
  },
  methods: {
    ...mapMutations(['increment']),
    ...mapActions(['incrementAsync']),
  }
}
  • Vuex 4:使用 Composition API 中的 computed 函數(shù)和普通的 JavaScript 函數(shù)來實現(xiàn)類似的功能。
import { computed, useStore } from 'vuex'
?
export default {
  setup() {
    const store = useStore()
?
    const count = computed(() => store.state.count)
    const doubleCount = computed(() => store.getters.doubleCount)
?
    const increment = () => {
      store.commit('increment')
    }
?
    const incrementAsync = () => {
      store.dispatch('incrementAsync')
    }
?
    return {
      count,
      doubleCount,
      increment,
      incrementAsync
    }
  }
}

Vuex4 支持選項式寫法的輔助函數(shù),在使用時和 Vuex3 一模一樣的。但是需要注意輔助函數(shù)不能在組合式寫法 setup 中使用。

響應(yīng)式的改進(jìn)

  • Vuex 3:使用 Vue 2 的響應(yīng)式系統(tǒng) ( Object.defineProperty ) 進(jìn)行狀態(tài)的監(jiān)聽和更新。
  • Vuex 4:使用 Vue 3 的響應(yīng)式系統(tǒng) ( proxy ) 進(jìn)行狀態(tài)的監(jiān)聽和更新,可以利用 Composition API 中的 reactivecomputed 函數(shù)進(jìn)行更加靈活和高效的狀態(tài)管理。

實質(zhì)上這是 Vue2 和 Vue3 的區(qū)別,只是由于 Vue 2 匹配的 Vuex 3,Vue 3 匹配的 Vuex 4 的原因,嚴(yán)格來說不能算作 Vuex3 與 Vuex4 的不同。

Vuex4 支持多例模式

Vuex 3 是單例模式的,即整個應(yīng)用只能有一個全局的 Vuex Store 實例。而在 Vuex 4 中,你可以通過 useStore 函數(shù)在不同組件中創(chuàng)建多個獨立的 Vuex Store 實例,從而支持多例模式。

以下是一個示例展示了如何在 Vuex 4 中使用 useStore 輔助函數(shù)創(chuàng)建多個獨立的 Vuex Store 實例:

<template>
  <div>
    <p>Counter 1: {{ counter1 }}</p>
    <p>Counter 2: {{ counter2 }}</p>
    <button @click="incrementCounter1">Increment Counter 1</button>
    <button @click="incrementCounter2">Increment Counter 2</button>
  </div>
</template>
?
<script>
import { useStore } from 'vuex'
?
export default {
  setup() {
    // 使用 useStore 輔助函數(shù)創(chuàng)建 Vuex Store 實例
    const store1 = useStore('store1')
    const store2 = useStore('store2')
?
    // 通過 store1.state.count 獲取第一個 Store 的狀態(tài)
    const count1 = store1.state.count
    // 通過 store2.state.count 獲取第二個 Store 的狀態(tài)
    const count2 = store2.state.count
?
    // 通過 store1.commit() 提交 mutations 到第一個 Store
    const incrementCounter1 = () => {
      store1.commit('increment')
    }
?
    // 通過 store2.commit() 提交 mutations 到第二個 Store
    const incrementCounter2 = () => {
      store2.commit('increment')
    }
?
    return {
      count1,
      count2,
      incrementCounter1,
      incrementCounter2
    }
  }
}
</script>

上述示例展示了如何在 Vue 組件中使用 useStore 輔助函數(shù)創(chuàng)建多個獨立的 Vuex Store 實例,并通過這些實例分別訪問和修改各自的狀態(tài)和 mutations。這是 Vuex 4 相對于 Vuex 3 的一個重要的改進(jìn),使得 Vuex 在支持多例模式的場景下更加靈活和可擴(kuò)展。

參考鏈接:

到此這篇關(guān)于Vuex3和Vuex4有哪些區(qū)別的文章就介紹到這了,更多相關(guān)Vuex3和Vuex4內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue在 Nuxt.js 中重定向 404 頁面的方法

    Vue在 Nuxt.js 中重定向 404 頁面的方法

    這篇文章主要介紹了Vue在 Nuxt.js 中重定向 404 頁面的方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-04-04
  • elementPlus中的Autocomplete彈出層錯位問題解決分析

    elementPlus中的Autocomplete彈出層錯位問題解決分析

    這篇文章主要介紹了elementPlus中的Autocomplete彈出層錯位問題解決分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • 詳解在vue中如何實現(xiàn)屏幕錄制與直播推流功能

    詳解在vue中如何實現(xiàn)屏幕錄制與直播推流功能

    屏幕錄制和直播推流是現(xiàn)代Web應(yīng)用中常用的功能,Vue作為一種流行的JavaScript框架,提供了一些工具和庫,可以方便地實現(xiàn)屏幕錄制和直播推流功能,本文將介紹如何在Vue中進(jìn)行屏幕錄制和直播推流,需要的朋友可以參考下
    2024-01-01
  • vue 輸入電話號碼自動按3-4-4分割功能的實現(xiàn)代碼

    vue 輸入電話號碼自動按3-4-4分割功能的實現(xiàn)代碼

    這篇文章主要介紹了vue 輸入電話號碼自動按3-4-4分割功能的實現(xiàn)代碼,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • 在Vue中獲取組件聲明時的name屬性方法

    在Vue中獲取組件聲明時的name屬性方法

    今天小編就為大家分享一篇在Vue中獲取組件聲明時的name屬性方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • Vue+ElementUI項目使用webpack輸出MPA的方法

    Vue+ElementUI項目使用webpack輸出MPA的方法

    這篇文章主要介紹了Vue+ElementUI項目使用webpack輸出MPA的方法,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08
  • Vue 修改網(wǎng)站圖標(biāo)的方法

    Vue 修改網(wǎng)站圖標(biāo)的方法

    這篇文章主要介紹了Vue 修改網(wǎng)站圖標(biāo)的方法,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下
    2020-12-12
  • vue2使用el-date-picker實現(xiàn)動態(tài)日期范圍demo

    vue2使用el-date-picker實現(xiàn)動態(tài)日期范圍demo

    這篇文章主要為大家介紹了vue2使用el-date-picker實現(xiàn)動態(tài)日期范圍示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • Vue cli+mui 區(qū)域滾動的實例代碼

    Vue cli+mui 區(qū)域滾動的實例代碼

    下面小編就為大家分享一篇Vue cli+mui 區(qū)域滾動的實例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01
  • vue中el-cascader三級聯(lián)動懶加載回顯問題解決

    vue中el-cascader三級聯(lián)動懶加載回顯問題解決

    本文主要介紹了vue中el-cascader三級聯(lián)動懶加載回顯問題解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06

最新評論