VUE3 之 HOOKS公共方法封装(TS)

场景:在项目开发过程中大概率会出现复用性方法,故为了节省代码量对公共方法进行抽象提取,将其封装为公共方法,以便于在不同组件中快速使用。

举例分页器方法提取:
src下新建hooks文件夹,新增ts文件:
在这里插入图片描述
文件内提取方法:

import { TABLE_PAGE } from '@/core/constants';
import { reactive, ref } from 'vue';

type sortParam = {
  field?: string | null;
  desc?: number | null;
};

export default function useSubTable(param: any) {
  const subPage = reactive({...TABLE_PAGE});
  const subQuery = reactive({} as sortParam);
  const subSearchParam: any = ref({});
  const subTableLoading = ref<boolean>(false);
  const subTableData = ref<any[]>([]);

  const getSubList = () => {
    if (param?.getSubList) {
      param.getSubList();
    }
  };

  const subChangePageSize = (size: number) => {
    subPage.pageSize = size;
    getSubList();
  };

  const subChangeCurrentPage = (pageNum: number) => {
    subPage.page = pageNum;
    getSubList();
  };

  const subChangeSort = (field: string, order: string) => {
    subQuery.field = field;
    subQuery.desc = order === 'asc' ? 0 : order === 'desc' ? 1 : null;
    getSubList();
  };

  const resetSubPage = () => {
    subPage.page = TABLE_PAGE.page;
    subPage.pageSize = TABLE_PAGE.pageSize;
    subPage.total = TABLE_PAGE.total;
    subQuery.field = null;
    subQuery.desc = null;
    subSearchParam.value = {};

    subTableData.value = [];
  };

  const subCommomSearch = () => {
    subChangeCurrentPage(1);
  };

  return {
    subPage,
    subQuery,
    subSearchParam,
    subChangePageSize,
    subChangeCurrentPage,
    subChangeSort,
    subCommomSearch,
    resetSubPage,
    subTableLoading,
    subTableData
  };
}

组件内使用:

import useSubTabel from "@/hooks/useSubTable";
//结构需要使用的方法
const {
  subPage,
  subSearchParam,
  subChangePageSize,
  subChangeCurrentPage,
  resetSubPage,
  subCommomSearch,
  subTableLoading,
  subTableData
} = useSubTabel({
  getSubList
});
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Vue 3 中,使用 TypeScript(TS)和 Composition API,可以创建可重用的自定义 Hooks。自定义 Hooks 是一种将逻辑和状态共享的方式,可以用于组件中。 以下是一个使用 TypeScript 和 Composition API 创建自定义 Hooks 的示例: ```typescript import { ref, onMounted, onUnmounted } from 'vue'; export function useCounter(initialValue: number, interval: number) { const count = ref(initialValue); let timer: NodeJS.Timeout; function start() { timer = setInterval(() => { count.value++; }, interval); } function stop() { clearInterval(timer); count.value = initialValue; } onMounted(start); onUnmounted(stop); return { count, start, stop }; } ``` 在上面的示例中,我们创建了一个名为 `useCounter` 的自定义 Hook。它接收一个初始值 `initialValue` 和一个时间间隔 `interval`。使用 `ref` 创建了一个可响应的 `count` 变量,并定义了 `start` 和 `stop` 方法用于启动和停止计数器。 在 `onMounted` 生命周期钩子中,我们调用了 `start` 方法来启动计数器。在 `onUnmounted` 生命周期钩子中,我们调用了 `stop` 方法来停止计数器。 在组件中使用自定义 Hook: ```typescript import { defineComponent } from 'vue'; import { useCounter } from '@/hooks/useCounter'; export default defineComponent({ setup() { const { count, start, stop } = useCounter(0, 1000); return { count, start, stop }; } }); ``` 在组件的 `setup` 函数中,我们使用 `useCounter` 自定义 Hook,获取了 `count`、`start` 和 `stop` 变量。然后我们可以在组件模板中使用它们。 自定义 Hooks 可以帮助我们将逻辑和状态进行封装,使代码更加模块化和可复用。在 Vue 3 中,结合 TypeScript 和 Composition API,可以更好地利用自定义 Hooks 来提高开发效率和代码质量。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

赫兹/Herzz

如果我的博文帮助到您请打赏支持

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值