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

vue3在setup中使用mapState解讀

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

vue3 setup使用mapState

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

創(chuàng)建一個(gè)hook

hooks/useMapState.ts

import { computed } from "vue"
import { mapState, useStore } from "vuex"
export default function (state:any) {
? ? // 1. 獲取實(shí)例 $store
? ? const store = useStore()
? ? // 2. 遍歷狀態(tài)數(shù)據(jù)
? ? const storeStateFns = mapState(state)
? ? // 3. 存放處理好的數(shù)據(jù)對(duì)象
? ? const storeState = {}
? ? // 4. 對(duì)每個(gè)函數(shù)進(jìn)行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語(yǔ)法糖中使用mapState

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

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語(yǔ)法糖中由于不能使用 return進(jìn)行返回,所以只能按照如下方式寫(xiě)了

在setup語(yǔ)法糖中使用

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

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

</script>

總結(jié)

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

相關(guān)文章

  • 簡(jiǎn)單學(xué)習(xí)5種處理Vue.js異常的方法

    簡(jiǎn)單學(xué)習(xí)5種處理Vue.js異常的方法

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

    vue計(jì)算屬性及使用詳解

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

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

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

    在Vue中使用this.$store或者是$route一直報(bào)錯(cuò)的解決

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

    深入探索Vue3.x中的七大高級(jí)用法

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

    讓ChatGPT解讀Vue3源碼過(guò)程解析

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

    一文教你學(xué)會(huì)在Vue3中自定義指令

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

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

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

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

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

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

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

最新評(píng)論