【无标题】

前端结束:vue+element-plus + ts

浏览器端 登录功能改造,在原来的账号密码登录 的基础上新增,短信验证码登录 的方式:

效果图:

1、号码输入正则校验、获取验证码之前再校验一次!

2、发送完验证码之后倒计时60秒,避免重复提交获取验证码请求

定义两个 el-tab-pane 标签,两个标签代表两种不同的登录方式(具体可参见element官方文档),该标签的name 属性需要唯一,如下贴上手机+验证码的标签内代码

复制代码
<template>
  <div class="login">
    <el-tabs v-model="activeName" type="border-card" class="login-tabs">
<el-tab-pane label="手机号码登录" name="mobile">
        <el-form ref="ssoLoginRef" :model="loginForm" :rules="ssoLoginRules" class="login-form">
          <h3 class="title">通用后台管理系统</h3>
          <el-form-item v-if="tenantEnabled" prop="tenantId">
            <el-select v-model="loginForm.tenantId" filterable placeholder="请选择/输入公司名称" style="width: 100%">
              <el-option v-for="item in tenantList" :key="item.tenantId" :label="item.companyName" :value="item.tenantId"></el-option>
              <template #prefix><svg-icon icon-class="company" class="el-input__icon input-icon" /></template>
            </el-select>
          </el-form-item>
          <el-form-item prop="phonenumber">
            <el-input v-model="loginForm.phonenumber" type="text" size="large" auto-complete="off" placeholder="手机号">
              <template #prefix><svg-icon icon-class="user" class="el-input__icon input-icon" /></template>
            </el-input>
          </el-form-item>
          <el-form-item prop="smsCode">
            <el-input v-model="loginForm.smsCode" type="text" size="large" auto-complete="off" placeholder="验证码" @keyup.enter="handleLogin">
              <template #prefix><svg-icon icon-class="password" class="el-input__icon input-icon" /></template>
              <template v-slot:append>
                <el-button @click="sendSmsCode" type="primary" :disabled="canClick">{{ content }}</el-button>
              </template>
            </el-input>
          </el-form-item>
          <el-form-item style="width: 100%">
            <el-button :loading="loading" size="large" type="primary" style="width: 100%" @click.prevent="handleLogin">
              <span v-if="!loading">登 录</span>
              <span v-else>登 录 中...</span>
            </el-button>
          </el-form-item>
        </el-form>
      </el-tab-pane>
      </el-tabs>
  </div>
</template>

在验证码输入框的下方面嵌入获取按钮代码:输入框和按钮就可以比较美观的贴合相接在一行上
<template v-slot:append>
                <el-button @click="sendSmsCode" type="primary" :disabled="canClick">{{ content }}</el-button>
              </template>

结合上述代码,定义的参数:
const canClick = ref(false);		// 控制按钮点击
const content = ref('发送验证码');	//  参数回显按钮的文本内容,不写死
const totalTime = ref(60);				// 默认获取验证码按钮点击间隙为 60s
let clock: ReturnType<typeof setInterval> | null = null;		// 定义60s倒计时内不可被点击对象锁

// 校验及控制,
/**
 * 获取短信验证码
 */
const sendSmsCode = () => {
  const phone = loginForm.value.phonenumber;
  const reg = /^1[3|4|5|6|7|8|9][0-9]\d{8}$/;
  if (!reg.test(phone)) {
    proxy.$modal.msgWarning('请输入正确的手机号码');
    return;
  }
  if (canClick.value) {
    return;
  }
  canClick.value = true;
  content.value = `${totalTime.value}s后重新发送`;
  clock = window.setInterval(() => {
    totalTime.value--;
    content.value = `${totalTime.value}s后重新发送`;

    if (totalTime.value < 0) {
      if (clock) {
        window.clearInterval(clock);
      }
      content.value = '发送验证码';
      totalTime.value = 60;
      canClick.value = false;
    }
  }, 1000);

//  以下为获取验证码接口实现逻辑,根据各自具体情况来

};
相关推荐
Aniugel1 分钟前
Vue国际化实现多语言方案
前端·vue.js·面试
白兰地空瓶7 分钟前
你以为树只是画图?不——它是算法面试的“隐形主角”
前端·javascript·算法
兔老大的胡萝卜1 小时前
pm2 部署nuxt4项目
javascript·nuxt4
阿蒙Amon1 小时前
JavaScript学习笔记:17.闭包
javascript·笔记·学习
Wpa.wk1 小时前
自动化测试 - 文件上传 和 弹窗处理
开发语言·javascript·自动化测试·经验分享·爬虫·python·selenium
l1t1 小时前
利用小米mimo为精确覆盖矩形问题C程序添加打乱函数求出更大的解
c语言·开发语言·javascript·人工智能·算法
composurext1 小时前
录音切片上传
前端·javascript·css
程序员小寒1 小时前
前端高频面试题:深拷贝和浅拷贝的区别?
前端·javascript·面试
zhougl9961 小时前
Vue 中的 `render` 函数
前端·javascript·vue.js
跟着珅聪学java1 小时前
HTML中设置<select>下拉框默认值的详细教程
开发语言·前端·javascript