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

vue3在setup中使用mapState解讀

 更新時間:2023年04月19日 08:36:45   作者:mrhaoxiaojun  
這篇文章主要介紹了vue3在setup中使用mapState方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

vue3 setup使用mapState

mapState和computed結(jié)合在Vue3版本中使用,廣大網(wǎng)友寫了很多,這里只做一個實戰(zhàn)后的應用筆記,不多贅述

創(chuàng)建一個hook

hooks/useMapState.ts

import { computed } from "vue"
import { mapState, useStore } from "vuex"
export default function (state:any) {
? ? // 1. 獲取實例 $store
? ? const store = useStore()
? ? // 2. 遍歷狀態(tài)數(shù)據(jù)
? ? const storeStateFns = mapState(state)
? ? // 3. 存放處理好的數(shù)據(jù)對象
? ? const storeState = {}
? ? // 4. 對每個函數(shù)進行computed
? ? Object.keys(storeStateFns).forEach(fnKey => {
? ? ? ? const fn = storeStateFns[fnKey].bind({ $store: store })
? ? ? ? // 遍歷生成這種數(shù)據(jù)結(jié)構(gòu) => {name: ref(), age: ref()}
? ? ? ? storeState[fnKey] = computed(fn)
? ? })
? ? return storeState
}

使用

<script lang="ts" setup>

import useMapState from "@/hooks/useMapState"

const myState:any = useMapState({
? includeList: (state: any) => state.keepAlive.includeList
})
const { includeList } = myState
</script>

vue3 setup語法糖中使用mapState

在Vue的組件中,要想使用Vuex中的多個State,我們經(jīng)過會借助mapState輔助函數(shù)進行獲取值,但是在Vue3中,通過computed的來獲取多個值的方法官方并未提供,話不多說,直接上代碼。

useMapState.js

import { computed } from "vue";
import { mapState, useStore } from "vuex"

export const useMapState = (getKeys) => {

? ? const store = useStore();
? ??
? ? const storeState = {}
? ? const storeFns = mapState(getKeys)

? ? Object.keys(storeFns).forEach((fnKeys) => {
? ? ? ? const fn = storeFns[fnKeys].bind({$store: store})
? ? ? ? storeState[fnKeys] = computed(fn)
? ? })

? ? return storeState
}

在setup函數(shù)中使用

<script>
import { useMapState } from ''./Hooks/useMapState.js'

export default {
? ? setup() {
? ? ? ? const storeState = useMapState(['title', 'counter'])

? ? ? ? return {
? ? ? ? ? ? ...storeState
? ? ? ? }
? ? }
}

</script>

在setup語法糖中由于不能使用 return進行返回,所以只能按照如下方式寫了

在setup語法糖中使用

<script setup>
import { useMapState } from ''./Hooks/useMapState.js'

const { title, counter } = useMapState(['title', 'counter'])

</script>

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 簡單學習5種處理Vue.js異常的方法

    簡單學習5種處理Vue.js異常的方法

    這篇文章主要介紹了簡單學習5種處理Vue.js異常的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,,需要的朋友可以參考下
    2019-06-06
  • vue計算屬性及使用詳解

    vue計算屬性及使用詳解

    計算屬性就是模板內(nèi)的表達式非常便利,但是設計它們的初衷是用于簡單運算的。這篇文章主要介紹了vue計算屬性詳解,需要的朋友可以參考下
    2018-04-04
  • vue中動態(tài)綁定表單元素的屬性方法

    vue中動態(tài)綁定表單元素的屬性方法

    下面小編就為大家分享一篇vue中動態(tài)綁定表單元素的屬性方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • 在Vue中使用this.$store或者是$route一直報錯的解決

    在Vue中使用this.$store或者是$route一直報錯的解決

    今天小編就為大家分享一篇在Vue中使用this.$store或者是$route一直報錯的解決,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • 深入探索Vue3.x中的七大高級用法

    深入探索Vue3.x中的七大高級用法

    Vue3.x 自發(fā)布以來,憑借其性能的顯著提升和更加靈活的組合式 API,已經(jīng)成為了現(xiàn)代前端開發(fā)的重要工具之一,除了基本用法外,Vue3.x 還提供了許多高級功能,本文將和大家一起深入探索Vue3.x中的七大高級用法,需要的朋友可以參考下
    2024-03-03
  • 讓ChatGPT解讀Vue3源碼過程解析

    讓ChatGPT解讀Vue3源碼過程解析

    這篇文章主要為大家介紹了讓ChatGPT解讀Vue3源碼過程解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • 一文教你學會在Vue3中自定義指令

    一文教你學會在Vue3中自定義指令

    這篇文章主要為大家詳細介紹一下如何在Vue3中實現(xiàn)自定義指令,文中的示例代碼講解詳細,具有一定的借鑒價值,需要的同學可以參考一下
    2022-07-07
  • 詳解VUE調(diào)用本地json的使用方法

    詳解VUE調(diào)用本地json的使用方法

    這篇文章主要介紹了VUE調(diào)用本地json的使用方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-05-05
  • 基于vue2.0動態(tài)組件及render詳解

    基于vue2.0動態(tài)組件及render詳解

    下面小編就為大家分享一篇基于vue2.0動態(tài)組件及render詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • Vue組件生命周期三個階段全面總結(jié)講解

    Vue組件生命周期三個階段全面總結(jié)講解

    Vue的生命周期就是vue實例從創(chuàng)建到銷毀的全過程,也就是new Vue() 開始就是vue生命周期的開始。Vue 實例有?個完整的?命周期,也就是從開始創(chuàng)建、初始化數(shù)據(jù)、編譯模版、掛載Dom -> 渲染、更新 -> 渲染、卸載 等?系列過程,稱這是Vue的?命周期
    2022-11-11

最新評論