Vue - 实现通过手机发送短信验证码登录

Vue 实现通过手机发送短信验证码登录,及60秒倒计时功能

<template>
  <div class="wrap">
    <el-form
      class="loginForm"
      :model="loginForm"
      :rules="loginFormRules"
      ref="loginFormRef"
      label-position="top"
    >
      <el-form-item label="手机号" prop="phone">
        <el-input v-model="loginForm.phone"></el-input>
      </el-form-item>
      <el-form-item label="手机验证码" prop="verificationCode">
        <el-input v-model="loginForm.verificationCode">
          <template slot="append">
            <el-button v-if="loginForm.showloginCode" type="primary" @click="getloginPhoneCode">获取验证码</el-button>
            <div v-else>{{ loginForm.count }}</div>
          </template>
        </el-input>
      </el-form-item>
      <el-form-item class="btns">
        <el-button type="primary" @click="login">登录</el-button>
      </el-form-item>
    </el-form>
  </div>
</template>
<script>
export default {
  data() {
    // 验证手机号是否合法
    var checkMobile = (rules, value, callback) => {
      const regMobile = /^(0|86|17951)?(13[0-9]|15[0123456789]|17[678]|18[0-9]|14[57])[0-9]{8}$/;
      if (regMobile.test(value) == true) {
        return callback();
      } else {
        callback(new Error("请输入合法的手机号"));
      }
    };
    // 验证输入的手机号验证码是否和存储的验证码相同
    var checkPhoneCode = (rules, value, callback) => {
      if (value == this.loginForm.contenttext) {
        return callback();
      } else {
        callback(new Error("验证码错误"));
      }
    };
    return {
      // 表单
      loginForm: {
        phone: "",
        verificationCode: "", //表单中展示的验证码
        contenttext: "", //向手机号发送的随机验证码
        timer: null,
        showloginCode: true, //判断展示‘获取验证码’或‘倒计时’
        count: "", //倒计时时间
      },
      // 验证规则
      loginFormRules: {
        phone: [
          { required: true, message: "请输入手机号", trigger: "blur" },
          { validator: checkMobile, trigger: "blur" },
        ],
        verificationCode: [
          { required: true, message: "请输入手机验证码", trigger: "blur" },
          { validator: checkPhoneCode, trigger: "blur" },
        ],
      },
    };
  },
  methods: {
    // 获取手机验证码
    getloginPhoneCode() {
      // 如果未输入手机号,结束执行
      if (this.loginForm.phone == "") {
        return;
      }
      // 获取随机数(4位数字)
      var numCode = "";
      for (var i = 0; i < 4; i++) {
        numCode += Math.floor(Math.random() * 10);
      }
      // 存储发送的验证码,用于验证输入的手机验证码是否和本地存储的相同
      this.loginForm.contenttext = numCode;
      // 向手机号发送验证码传入的参数
      let phoneCode = {
        phonenum: this.loginForm.phone,
        contenttext: "您正在修改密码,验证码为:" + numCode + ",切勿将验证码泄露给他人。",
      };
      // 调用接口,向手机号发送验证码
      this.$axios.post("接口地址", phoneCode).then((res) => {
        if (res.status != 200) {
          return this.$message.error("验证码发送失败!");
        } else {
          // 当验证码发送成功,开始60秒倒计时
          const TIME_COUNT = 60;
          if (!this.loginForm.timer) {
            this.loginForm.showloginCode = false;
            this.loginForm.count = TIME_COUNT;
            this.loginForm.timer = setInterval(() => {
              if (
                this.loginForm.count > 0 &&
                this.loginForm.count <= TIME_COUNT
              ) {
                this.loginForm.count -= 1;
              } else {
                this.loginForm.showloginCode = true;
                clearInterval(this.loginForm.timer);
                this.loginForm.timer = null;
              }
            }, 1000);
          }
        }
      });
    },
    // 开始登录
    login() {
      this.$refs.loginFormRef.validate((valid) => {
        if (valid) {
          console.log("开始登录");
        } else {
          console.log("error submit!!");
        }
      });
    },
  },
};
</script>
<style scoped>
.loginForm {
  width: 500px;
  margin: 0 auto;
}
.btns {
  text-align: right;
}
</style>
  • 10
    点赞
  • 72
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
Vue是一种流行的JavaScript框架,用于构建用户界面。要编写一个手机短信验证码登录的页面,我们可以按照以下步骤进行: 1. 创建Vue应用:首先,在HTML文件中引入Vue库,并在JavaScript文件中创建Vue实例。 2. 设计页面结构:在Vue实例中,使用HTML和Vue的模板语法来设计页面结构。可以包括一个表单和相关的输入框、按钮等元素。 3. 定义数据和方法:在Vue实例中,定义数据属性来存储用户输入的手机号码和验证码,以及其他需要的数据。同时,定义方法来处理用户的点击事件,例如发送验证码、登录等操作。 4. 实现发送验证码功能:在发送验证码的方法中,可以使用Vue的生命周期钩子函数mounted,来模拟发送短信验证码的功能。在这个方法中,可以生成一个随机的验证码,并将其显示在页面上。 5. 验证手机号码和验证码:在登录方法中,可以比较用户输入的手机号码和验证码与之前生成的手机号码和验证码是否匹配。如果匹配成功,则可以执行登录操作。 6. 处理用户界面的交互和反馈:根据用户的操作和输入,可以使用Vue的数据绑定和条件渲染来实时更新页面中的内容。例如,在用户点击发送验证码按钮后,可以禁用按钮一段时间,并显示倒计时。 7. 添加样式和美化页面:根据需求和个人喜好,可以使用CSS样式来美化页面,使其更加吸引和友好。 通过以上步骤,可以完成一个简单的手机短信验证码登录页面的开发。当用户输入正确的手机号码和验证码并点击登录时,可以进行进一步的后续操作,例如跳转到其他页面或者显示登录成功的提示信息。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值