【Vue】mapState的hooks封装(Vue3)

本文介绍如何在Vue3中使用自定义Hooks封装mapState,实现从Vuex中批量获取状态值。通过实例展示了传入数组和对象两种方式的使用方法,并与Vue2进行了对比。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

vue2中,可以在计算属性中,直接使用mapState从vuex中取出多个状态值,Vue3提供了useStore进行取值,但需要分别取值,为了能够同时取值,封装hooks如下

mapGetters的使用和封装

mapState的hooks封装

封装

目录:src/hooks/useState.js

// useState.js
import { useStore, mapState } from "vuex";
import { computed } from "vue";

export default function (mapper) {
  // 拿到store
  const store = useStore();

  // 获取相应的对象 : {name:function,gender:function}
  const storeStateFns = mapState(mapper);

  // 进行 $store 指向 ,并赋值
  const storeState = {};
  Object.keys(storeStateFns).forEach((Fnkey) => {
    // setup中无this指向
    // 在computed中计算state时需要  $store 指向 ,所以使用bind() 绑定 $store
    const fn = storeStateFns[Fnkey].bind({ $store: store });
    storeState[Fnkey] = computed(fn);
  });

  //返回
  return storeState;
}

使用

传入数组

<script setup>
import useState from '@/hooks/useState'
//传入数组
const person = useState(['name', 'gender'])
//返回值是对象
console.log(person.name.value);//yyy
</script>

在这里插入图片描述

传入对象

<script setup>
import useState from '@/hooks/useState'
//传入数组
const person = useState(
{    sName: (state) => state.name,
   sGender: (state) => state.gender
 })
//返回值是对象
console.log(person.name.value);//如下图
</script>

在这里插入图片描述

Vue2的用法

<script>
import { mapState } from 'vuex';

export default {
    computed: {
        ...mapState([
            'name',
            'gender'
        ])
    },
};
</script>
<think>好的,我现在需要帮助用户了解如何在Vue3封装Hooks。首先,我需要回顾一下Vue3的Composition API,因为Hooks在这里是通过组合式函数实现的。用户可能已经知道Hooks的基本概念,但需要具体的步骤和示例。 根据提供的引用内容,Vue3Hooks结合了响应式系统,用于逻辑复用,类似于React Hooks但有所不同。用户可能需要一个清晰的示例教程,比如封装一个useTable的Hooks,如引用[2]提到的。我应该分步骤讲解,从创建Hooks文件到定义响应式数据,再到添加方法,最后在组件中使用。 我需要确保每一步都解释清楚,比如使用ref和reactive创建响应式状态,如何导出函数,以及组件中如何导入和使用。同时,要强调封装的好处,比如复用性、可维护性,以及和Mixin的对比,如引用[3]提到的。 可能还需要考虑如何处理异步请求,比如在useTable中获取数据,这时可以使用async/await。此外,要提到最佳实践,比如单一职责和自定义配置,让Hooks更灵活。最后,生成相关问题,帮助用户进一步学习,比如封装Hooks的注意事项或者与React Hooks的区别。 需要检查是否遵循了用户提供的格式要求,比如行内数学表达式是否正确,但这里可能用不上数学公式。重点是将步骤用代码块展示,语言标记正确,结构清晰。确保引用标识正确添加,比如在提到复用性时引用[3],提到useTable时引用[2]。 现在组织内容:简介、封装步骤(分点)、示例代码、最佳实践、相关问题。确保每个部分自然衔接,引用放置在相关段落末尾。可能需要先定义什么是Hooks,再逐步展开,避免术语混淆。最后验证示例代码是否正确,比如useTable的函数结构,是否正确使用reactive和生命周期钩子。</think>### Vue3 Hooks 封装示例教程 #### 一、Hooks 封装核心思想 Vue3 Hooks(组合式函数)是通过组合式API封装响应式逻辑的代码复用方案。其核心是将组件中的状态和逻辑抽离为独立函数,通过响应式系统实现高效复用[^3]。 --- #### 二、封装步骤与示例(以 `useTable` 为例) ##### 1. 创建 Hooks 文件 ```javascript // useTable.js import { ref, reactive, onMounted } from &#39;vue&#39; import { fetchTableData } from &#39;@/api&#39; // 假设存在数据接口 export default function useTable(options = {}) { // 定义响应式状态 const state = reactive({ loading: false, data: [], pagination: { current: 1, pageSize: 10, total: 0 } }) // 定义业务方法 const loadData = async () => { state.loading = true try { const params = { page: state.pagination.current, pageSize: state.pagination.pageSize } const res = await fetchTableData(params) state.data = res.data state.pagination.total = res.total } finally { state.loading = false } } // 生命周期挂钩 onMounted(() => { loadData() }) // 返回可复用状态与方法 return { state, loadData } } ``` ##### 2. 在组件中使用 ```vue <template> <div> <table v-loading="state.loading"> <!-- 表格内容渲染 --> </table> <Pagination :current="state.pagination.current" :total="state.pagination.total" @change="handlePageChange" /> </div> </template> <script setup> import useTable from &#39;./useTable&#39; const { state, loadData } = useTable() const handlePageChange = (page) => { state.pagination.current = page loadData() } </script> ``` --- #### 三、封装最佳实践 1. **单一职责原则** 每个Hooks应只解决一个特定问题,例如 `useForm` 处理表单逻辑,`useFetch` 管理数据请求[^1]。 2. **响应式状态管理** 优先使用 `reactive` 管理关联状态对象,用 `ref` 处理独立值: $$ \text{响应式变量} = \begin{cases} \text{reactive()} & \text{复杂对象} \\ \text{ref()} & \text{基础类型} \end{cases} $$ 3. **支持自定义配置** 通过参数注入提升灵活性: ```javascript function useTable({ immediate = true }) { // 立即加载数据配置 } ``` --- #### 四、对比传统方案优势 | 方案 | 代码组织 | 类型推导 | 作用域隔离 | |-----------|------|------|-------| | Mixins | 差 | 困难 | 弱 | | Hooks | 清晰 | 友好 | 强 | [^2] ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值