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 = 
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、付费专栏及课程。

余额充值