vben admin 项目学习day2:登录首页 Login

template结构

1. AppLocalePicker            # 切换语言的下拉菜单

2. AppLogo                         # 左上角的logo部分

3. LoginForm                      # 登录

4. ForgetPasswordForm     # 忘记密码

5. RegisterForm                  # 注册

6. MobileForm                     # 手机登录

7. QrCodeForm                   # 二维码登录

如何切换组件

每个组件的标签都使用 v-show v-if 控制组件是否显示,如:

 

 

 来看看 getShow 函数,其中的参数 getLoginState 来自 useLogin 下的 useLoginState

import { LoginStateEnum, useLoginState, useFormRules, useFormValid } from './useLogin';
const { setLoginState, getLoginState } = useLoginState();

// LoginForm.vue中
const getShow = computed(() => unref(getLoginState) === LoginStateEnum.LOGIN);

// RegisterForm.vue中
const getShow = computed(() => unref(getLoginState) === LoginStateEnum.REGISTER);

继续来看 useLoginState,其中包含:

①currentState.value的更新;

②currentState.value的获取;

③返回登录页LoginForm时currentState.value的更新

export enum LoginStateEnum {
  LOGIN,
  REGISTER,
  RESET_PASSWORD,
  MOBILE,
  QR_CODE,
}

const currentState = ref(LoginStateEnum.LOGIN);

export function useLoginState() {
  function setLoginState(state: LoginStateEnum) {
    // state为对应登录选项的index,将currentState中的value更新为目前的state
    currentState.value = state;
  }

  const getLoginState = computed(() => currentState.value);

  function handleBackLogin() {
    // LoginStateEnum.LOGIN=0,将currentState.value设置为0
    setLoginState(LoginStateEnum.LOGIN);
  }

  return { setLoginState, getLoginState, handleBackLogin };
}

因此当 currentState.value === LoginStateEnum.xxx(当前组件)时,该组件才显示。

如何修改state

从上面我们知道要获取 currentState.value 来判断显示哪个组件,那么当组件切换时,如何进行currentState.value 的更新?更新的函数为:setLoginState(见上),何时调用呢?

举例说明:在LoginForm.vue中,当点击按钮切换到其他组件时,触发的事件即为setLoginState,传入其中的参数即为state

 在MobileForm.vue中,当点击返回按钮时,就会切换到LoginForm.vue,此时触发的事件为

handleBackLogin 

至此,Login.vue分析完毕。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值