vue3-Hook

Hook

(1) Hook是用来作什么的?

vue3里面可以自定义hook 主要是用来存储一些复用的逻辑、变量的封装。相当于vue2里面的minins

(2)既然vue2有minins为什么vue3提出了Hook?

minins虽然实现了重复代码的提取,但是minins的缺点就是

(1)组件的data、methods、filters会覆盖mixins里的同名data、methods、filters。

(2)变量不好找,可读性不好,维护起来比较复杂

minins的声明周期调用的比引入他的组件快,即;minins的beforeCreate->组件的beforeCreate->mixins的Create->组件的Create

为了解决这些问题,于是有了Hook:

(1)不同于mixin, hook是函数,这样就可以帮助我们提高代码的复用性, 让我们能在不同的组件中都利用 hooks 函数

一个png转baseUrl的小例子

hook/index.ts

import { onMounted } from 'vue';

type Option = {
    el:string
}

export default function(option: Option):Promise<{baseUrl:string}>{
    return new Promise((resolve)=>{
        onMounted(()=>{
            const file:HTMLImageElement = document.querySelector(option.el) as HTMLImageElement;
            file.onload = ():void=>{
                resolve({
                    baseUrl:toBase64(file)
                })
            }
        })
    
        const toBase64 = (el:HTMLImageElement):string=>{
            const canvas:HTMLCanvasElement = document.createElement('canvas')
            const ctx = canvas.getContext('2d') as CanvasRenderingContext2D
            canvas.width = el.width
            canvas.height = el.height
            ctx.drawImage(el,0,0,canvas.width,canvas.height)
            console.log(el.width);
            return canvas.toDataURL('image/png')
             
        }

    })


}

index,vue

<template>

  <div>
  <img src="./assets/test.png" width="300" height="300" id="img">
  </div>

</template>

<script setup lang="ts">
import useBase64 from './components/bzhan/hooks'
useBase64({el:"#img"}).then(res=>{
  console.log(res.baseUrl);
  
})

</script>


打印结果

在这里插入图片描述

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用 `vue3-google-login` 库在 Vue 3 中获取用户信息,你可以按照以下步骤进行操作: 1. 在 Vue 3 项目中安装 `vue3-google-login`: ```bash npm install vue3-google-login ``` 2. 在你的 Vue 组件中引入并使用 `vue3-google-login`: ```vue <template> <div> <google-login :clientId="YOUR_CLIENT_ID" @success="onSuccess" @failure="onFailure" ></google-login> <button v-if="isSignedIn" @click="getUserInfo">获取用户信息</button> <div v-if="userInfo"> <p>Name: {{ userInfo.name }}</p> <p>Email: {{ userInfo.email }}</p> <p>Profile Picture: {{ userInfo.picture }}</p> </div> </div> </template> <script> import { useGoogleLogin } from 'vue3-google-login' export default { setup() { const { signIn, signOut, isSignedIn, userInfo, getUserInfo } = useGoogleLogin({ clientId: 'YOUR_CLIENT_ID', scope: 'email profile', fetchBasicProfile: true, }) const onSuccess = (googleUser) => { // 登录成功回调函数 console.log('登录成功', googleUser) } const onFailure = (error) => { // 登录失败回调函数 console.log('登录失败', error) } return { signIn, signOut, isSignedIn, userInfo, getUserInfo, onSuccess, onFailure, } }, } </script> ``` 在以上示例代码中,我们使用 `useGoogleLogin` 自定义 hook 来处理谷歌登录。`useGoogleLogin` 返回了一些函数和数据,包括 `signIn` 和 `signOut`,用于登录和退出登录,`isSignedIn` 用于检查用户是否已登录,`userInfo` 用于存储用户信息,以及 `getUserInfo` 用于获取用户信息。 当用户成功登录时,`onSuccess` 回调函数将被触发,并且你可以在其中访问 `googleUser` 对象来获取更多用户信息。你可以根据需要将 `googleUser` 中的信息发送到后端进行处理。 当用户已登录并点击 "获取用户信息" 按钮时,`getUserInfo` 函数将被调用,该函数将更新 `userInfo` 数据并在模板中显示用户信息。 请确保将示例代码中的 `YOUR_CLIENT_ID` 替换为你自己的谷歌应用的客户端 ID。 希望这可以帮助到你!如果你有任何疑问,请随时问我。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值