首页 > 其他分享 >Vue自定义hook

Vue自定义hook

时间:2022-12-27 21:44:52浏览次数:38  
标签:Vue 鼠标 自定义 usePoint point hook event

自定义hook函数

  • 什么是hook?—— 本质是一个函数,把setup函数中使用的Composition API进行了封装。

  • 类似于vue2.x中的mixin。

  • 自定义hook的优势: 复用代码, 让setup中的逻辑更清楚易懂。

Demo.vue:

<template>
    <h2>当前求和为:{{sum}}</h2>
    <button @click="sum++">点我+1</button>
    <hr>
    <h2>当前点击时鼠标的坐标为:x:{{point.x}},y:{{point.y}}</h2>
</template> 
<script>
    import {ref} from 'vue'
    import usePoint from '../hooks/usePoint'
    export default {
        name: 'Demo',
        setup(){
            //数据
            let sum = ref(0)
            let point = usePoint() 
            //返回一个对象(常用)
            return {sum,point}
        }
    }
</script>

 

将会重复使用的代码封装到 usePoint.js

import {reactive,onMounted,onBeforeUnmount} from 'vue'
export default function (){
    //实现鼠标“打点”相关的数据
    let point = reactive({
        x:0,
        y:0
    })

    //实现鼠标“打点”相关的方法
    function savePoint(event){
        point.x = event.pageX
        point.y = event.pageY
        console.log(event.pageX,event.pageY)
    }

    //实现鼠标“打点”相关的生命周期钩子
    onMounted(()=>{
        window.addEventListener('click',savePoint)
    })

    onBeforeUnmount(()=>{
        window.removeEventListener('click',savePoint)
    })

    return point
}

 

  

标签:Vue,鼠标,自定义,usePoint,point,hook,event
From: https://www.cnblogs.com/anjingdian/p/17009065.html

相关文章

  • Vue3生命周期
    Vue3.0中可以继续使用Vue2.x中的生命周期钩子,但有有两个被更名:beforeDestroy改名为 beforeUnmountdestroyed改名为 unmountedVue3.0也提供了CompositionAPI形式......
  • Vue:TDesign Starter 定制改造,中后台管理系统(前端)
    目前来说,TDesignStarter和普通的业务代码一样,没法做到像npm包一样通过升级来达到同步新增功能或修复问题的效果,所以这里记录一下TDesignStarter的定制改造过程。0.......
  • Vue3之watchEffect函数
    watchEffect函数watch的套路是:既要指明监视的属性,也要指明监视的回调。watchEffect的套路是:不用指明监视哪个属性,监视的回调中用到哪个属性,那就监视哪个属性。wat......
  • 一文理解vuex和pinia的区别
    一文理解vuex和pinia的区别......
  • SpringBoot vue
    springboot整合vue就行前后端完全分离,监听器,过滤器,拦截器https://github.com/ninuxGithub/spring-boot-vue-separateAblogbuiltupwithSpringBootinthebackend......
  • vue3 项目中设置组件name
    在开发vue3项目时,如果使用的是setup语法,那么想要给组件设置name属性。可以通过下面的两种形式。在组件中额外创建一个script脚本,在其中采用选项式api的写法,设置name属性......
  • Vue
    Vue输入绑定//输入绑定v-model//修饰符.lazy并不是实时改变,而是在失去焦点或者按回车时才会更新.number将输入转换成Number类型.trim可以自动过滤输入首尾的......
  • vue环境安装与配置
    https://www.jb51.net/article/251371.htmhttps://www.yht7.com/news/193355一、下载和安装Vue:https://nodejs.org/en/download/安装目录:D:\ProgramFiles\nodej......
  • 前端___Vue小案例
    Vue小案例包含bootstrap和Vue的使用文本输入框,复选框与Vue变量的绑定包含v-model,@,:,v-for,computed,methods,等语法的使用...仅供复习时使用源码:<!DOCTYPEhtml><ht......
  • iOS6下自定义UI控件外观效果
    尽管iOS原生的UI控件就已经有很不错的显示效果,但是App开发者仍然希望自己的产品与众不同,所以自定义UI外观成了每个App产品开发必做之事。今天就来做一个在iOS6下实现自定义U......