vue3中的hooks如何使用

一、 什么是hooks

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

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

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

二、hooks的用法

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

vue3中的hooks如何使用

立即学习“前端免费学习笔记(深入)”;

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

  1. // src/hooks/useMousePosition.tsimport { ref, onMounted, onUnmounted, Ref } from 'vue'interface MousePosition {  x: Ref,  y: Ref}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文件中:

  1. // src/views/test.vue  
        

    X: {{ x }}

        

    Y: {{ y }}

      
    import { defineComponent} from 'vue'// 引入hooksimport useMousePosition from '../../hooks/useMousePosition'export default defineComponent({ setup () { // 使用hooks功能 const { x, y } = useMousePosition() return { x, y } }})

登录后复制

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

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

点点赞赏,手留余香

给TA打赏
共0人
还没有人赞赏,快来当第一个赞赏的人吧!
    编程技术

    Vue3中shallowRef和shallowReactive如何使用

    2025-4-1 16:32:20

    编程技术

    Vue3中的toRef和toRefs怎么使用

    2025-4-1 16:32:33

    0 条回复 A文章作者 M管理员
    欢迎您,新朋友,感谢参与互动!
      暂无讨论,说说你的看法吧
    个人中心
    购物车
    优惠劵
    今日签到
    私信列表
    搜索