Vue3中的hook

自定义hook函数

本质上hook是一个函数,把setup函数中使用的Composition API进行了封装。

类似于Vue2中的mixin

其使用目的是为了复用代码,让setup中的逻辑更加清楚易懂

SighIn.ts

/* eslint-disable no-unused-vars */
import { ref, Ref } from 'vue';
import { getPublicKeyAPI, loginAPI, LoginParam } from '@/api/userManage';
import { JSEncrypt } from 'jsencrypt';

export type Callback = () => void
export interface SignInState {
  publicKey: Ref<string>,
  token: Ref<string>,
  getPublicKey: (success?: Callback, fail?: Callback) => void,
  login: (param: LoginParam, success?: Callback, fail?: Callback) => void
}

class SignIn {
  publicKey = ref('')

  token = ref('')

  /**
   * 获取公钥
   * @param success 成功回调
   * @param fail 失败回调
   */
  getPublicKey(success?: Callback, fail?: Callback): void {
    getPublicKeyAPI()
      .then(({ data }: any) => {
        this.publicKey.value = data;
        success && success();
      })
      .catch(() => {
        fail && fail();
      });
  }

  /**
   * 登录
   * @param param
   * @param success
   * @param fail
   */
  login(param: LoginParam, success?: Callback, fail?: Callback): void {
    try {
      const toLogin = (): void => {
        // RSA 加密
        const jsencrypt = new JSEncrypt();
        jsencrypt.setPublicKey(this.publicKey.value);
        const RSApassword = jsencrypt.encrypt(param.credential);
        if (RSApassword) {
          param.credential = RSApassword;
          loginAPI(param).then(({ data }) => {
            this.token = data.token;
            localStorage.setItem('token', this.token.value);
            success && success();
          });
        } else {
          throw new Error();
        }
      };
      this.getPublicKey(toLogin);
    } catch (error) {
      fail && fail();
    }
  }
}

export default () => new SignIn();

 

  • 7
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值