vue3中的hooks总结

vue3的hooks总结

vue3中的hooks其实是函数的写法,就是将文件的一些单独功能的js代码进行抽离出来,放到单独的js文件中。这样其实和我们在vue2中学的mixin比较像。下面我们总结一下如何去书写hooks。

首先应该先建立一个hooks文件夹:其目的是为了存放hook文件。

vue3中的hooks总结_第1张图片

建立相关的hook文件:一般使用use开头。

计数器的hook

vue3中的hooks总结_第2张图片

useTitle的hooks

vue3中的hooks总结_第3张图片

useScrollPostion用来监测浏览器页面的滚动情况

vue3中的hooks总结_第4张图片

useMousemove监听鼠标位置的hook

vue3中的hooks总结_第5张图片

useLocalStorage可以本地存储

vue3中的hooks总结_第6张图片

vue3自定义hooks

  • 自定义hooks就类似组件一样只不过只封装js,当有一段js代码需要复用可以把他封装成一个hooks进行复用
  • 需求,在别的页面插入一个hooks实现记录鼠标点击就的坐标

可以在文件中建一个专门写hooks的文件夹可以与 component同级

vue3中的hooks总结_第7张图片

把需要复用的代码写在这个js文件中

import { reactive } from '@vue/reactivity'
import{onMounted} from 'vue'
export default function(){
     let points=reactive({
          x:0,
          y:0
     })
     function myclick(event){
         points.x=event.pageX
         points.y=event.pageY
     }
     onMounted(()=>{
      //点击的是窗口所以要给窗口定义点击事件
     window.addEventListener("click",myclick)
     })
     //这里需要有一个返回值,如果不给返回值接收的是一个函数,接收的是undefind
     return points
}

写完了hooks文件就可在别的地方引用了(可以跟别的代码写在一起)

vue3中的hooks总结_第8张图片

vue3中的hooks总结_第9张图片

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

你可能感兴趣的:(vue3中的hooks总结)