Vue3自定义的Hooks就是爽

1.组合式 API 和选项 API

Vue2 提供的编程方式是 Options API,即选项式 API

在日常的开发功能的时候,我们需要在 data 、methods、computed 之间来回找代码。如果功能非常复杂, data 、methods、computed 等里面的代码就会非常长,不好维护。

后来 Vue3 出现了,它提供的编程方式是 Composition API,即组合式 API

Vue 的自定义 Hooks 是一种封装可重用逻辑的方式。它允许你将复杂的逻辑提取出来,形成独立的函数,然后在不同的组件中复用。这样可以避免在多个组件中重复编写相同的逻辑,提高代码的可读性和可维护性。

案例1

创建一个简单的计数器 Hooks

import {ref} from 'vue'
export function userCount(){
    const count = ref(0)
   //+
    const increment = ()=>{
        count.value++;
    }
    //-
    const decrement = ()=>{
        count.value--;
    }
    return {count,increment,decrement}
}

使用:

<template>
	<div>
		<p>count: {{ count }}</p>
		    <el-divider></el-divider>     <el-button
			type="primary"
			@click="increment"
			>新增</el-button
		>
		    <el-button type="success" @click="decrement">减少</el-button>   
	</div>
</template>

<script setup lang="ts">
// 导入 hooks
import { userCount } from "../../hooks/userCount"
// 解构引入
const { count, increment, decrement } = userCount()
</script>

<style lang="scss" scoped></style>

效果如下:

案例2

创建一个监听浏览器窗口大小变化的 Hooks

import { ref, onMounted, onUnmounted } from 'vue'
export function usewinResize() {
    const width = ref(window.innerWidth)
    const height = ref(window.innerHeight)
    const handleResize = () => {
        width.value = window.innerWidth;
        height.value = window.innerHeight;
    }
    onMounted(() => {
        window.addEventListener('resize', handleResize);
    })
    onUnmounted(() => {
        window.removeEventListener('resize', handleResize);
    })
    return { width, height };
}

使用:

<template>
	<div>
		<p>count: {{ count }}</p>
		<el-divider></el-divider>
		<el-button type="primary" @click="increment">新增</el-button>
		<el-button type="success" @click="decrement">减少</el-button>
		<el-divider></el-divider>
		<p>浏览器窗口宽度: {{ width }}</p>
		<p>浏览器窗口高度: {{ height }}</p>
	</div>
</template>

<script setup lang="ts">
// 导入 hooks
import { userCount } from "../../hooks/userCount"
import { usewinResize } from "../../hooks/useWinResize"
// 解构引入
const { count, increment, decrement } = userCount()
const { width, height } = usewinResize()
</script>

<style lang="scss" scoped></style>

效果如下:

对您有帮助的话辛苦您关注一下微信公众号哦!谢谢

清宁时光秀

Vue3自定义hooks函数是在Vue3中使用Composition API的一种方式。它允许我们在setup函数中定义函数和状态,并将其封装在外部的js文件中,以便在主文件中进行调用。通过使用自定义hooks函数,我们可以实现函数的复用,使代码更加简洁高效。自定义hooks函数可以帮助我们提高代码的复用性,让我们能够在不同的组件中都利用hooks函数。虽然使用Composition API可能会比之前的Vue写法更加麻烦,但是通过使用自定义hooks函数,我们可以实现函数编程的复用,使代码更加简洁高效。在前端领域,Hooks并没有明确定义,但在Vue3中,自定义Hooks函数被广泛应用于开发中,它可以集成定义一些可复用的方法,让我们的代码更加丰满。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [学习Vue3 第二十八章(自定义Hooks)](https://blog.csdn.net/qq1195566313/article/details/123271189)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [对vue3自定义hooks的理解](https://blog.csdn.net/a1598452168YY/article/details/128294569)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [vue3必学技能--自定义Hooksvue3更加畅快](https://blog.csdn.net/qq_39197547/article/details/125740319)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

晴天飛 雪

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值