您的位置:首页 > 技术中心 > 前端框架 >

vue3中的hooks如何使用

时间:2023-05-12 09:48

一、 什么是hooks

hook是钩子的意思,看到“钩子”是不是就想到了钩子函数?事实上,hooks 还真是函数的一种写法。

vue3 借鉴 react hooks 开发出了 Composition API ,所以也就意味着 Composition API 也能进行自定义封装 hooks

vue3 中的 hooks 就是函数的一种写法,就是将文件的一些单独功能的js代码进行抽离出来,放到单独的js文件中,或者说是一些可以复用的公共方法/功能。其实 hooksvue2 中的 mixin 有点类似,但是相对 mixins 而言, hooks 更清楚复用功能代码的来源, 更清晰易懂。

二、hooks的用法

1.在src中创建一个hooks文件夹,用来存放hook文件

vue3中的hooks如何使用

2.根据需要写hook文件,比如要实现一个功能就是在 点击页面时,记录鼠标当前的位置,可以在hooks文件夹中新建一个文件useMousePosition.ts

// src/hooks/useMousePosition.tsimport { ref, onMounted, onUnmounted, Ref } from 'vue'interface MousePosition {  x: Ref<number>,  y: Ref<number>}function useMousePosition(): MousePosition {  const x = ref(0)  const y = ref(0)  const updateMouse = (e: MouseEvent) => {    x.value = e.pageX    y.value = e.pageY  }  onMounted(() => {    document.addEventListener('click', updateMouse)  })  onUnmounted(() => {    document.removeEventListener('click', updateMouse)  })  return { x, y }}export default useMousePosition

3.hook文件的使用:在需要用到该hook功能的组件中的使用,比如在 test.vue文件中:

// src/views/test.vue<template>  <div>    <p>X: {{ x }}</p>    <p>Y: {{ y }}</p>  </div></template><script lang="ts">import { defineComponent} from 'vue'// 引入hooksimport useMousePosition from '../../hooks/useMousePosition'export default defineComponent({  setup () {    // 使用hooks功能    const { x, y } = useMousePosition()    return {      x,      y    }  }})</script>

以上就是vue3中的hooks如何使用的详细内容,更多请关注Gxl网其它相关文章!

热门排行

今日推荐

热门手游