栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > JavaScript

Vue中添加手机验证码组件功能操作方法

JavaScript 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Vue中添加手机验证码组件功能操作方法

什么是组件:

组件是Vue.js最强大的功能之一。组件可以扩展HTML元素,封装可重用的代码。在较高层面上,组件是自定义的元素,Vue.js的编译器为它添加特殊功能。在有些情况下,组件也可以是原生HTML元素的形式,以is特性扩展。

写在前面:

今天要实现的功能是在 完善个人信息页面(vue)中添加手机验证码组件,当用户点击 手机选项时,弹出获取验证码组件,完成验证手机的功能:

这里考虑到功能的复用,我把当前弹出手机验证码的操作放在了单独的组件中:

并把当前组件放在需要使用它的组件中,这里需要注意的是,在控制 绑定手机组件的显示和隐藏的时候,出现了一个小问题:点击 “手机” 按钮需要显示当前组件,但什么时候去隐藏当前的组件呢,我是这样想的:

  情况1:用户已经输完了手机号并通过了验证,点击"确定"按钮的时候需要隐藏当前组件;

  情况2:用户没有完成手机验证,但又不想继续,点击当前手机的任意位置(除去“确定”按钮、手机号输入框和 验证码输入框)都应该隐藏当前组件;

基于这两种情况,我在父组件中给子组件添加了一个容器:

  •   手机号*     
  • 通过控制 父div 的显示状态来控制子组件的显示状态,

    methods:{
      // 手机号验证
      verifyPhone(){
       this.verifyShow=!this.verifyShow;
      },
     },

    在验证组件中的逻辑控制如下:

    
    
    

    其中,获取验证码和验证短信验证码的逻辑还没有写入。

    PS:下面给大家补充一段vue短信验证码组件实例代码:

    Vue.component('timerBtn',{
      template: '',
      props: {
        second: {
          type: Number,
          default: 60
        },
        disabled: {
          type: Boolean,
          default: false
        }
      },
      data:function () {
        return {
          time: 0
        }
      },
      methods: {
        run: function () {
          this.$emit('run');
        },
        start: function(){
          this.time = this.second;
          this.timer();
        },
        stop: function(){
          this.time = 0;
          this.disabled = false;
        },
        setDisabled: function(val){
          this.disabled = val;
        },
        timer: function () {
          if (this.time > 0) {
     this.time--;
     setTimeout(this.timer, 1000);
          }else{
     this.disabled = false;
          }
        }
      },
      computed: {
        text: function () {
          return this.time > 0 ? this.time + 's 后重获取' : '获取验证码';
        }
      }
    });
    var vm = new Vue({
      el:'#app',
      methods:{
        sendCode:function(){
          vm.$refs.timerbtn.setDisabled(true); //设置按钮不可用
          hz.ajaxRequest("sys/sendCode?_"+$.now(),function(data){
     if(data.status){
       vm.$refs.timerbtn.start(); //启动倒计时
     }else{
       vm.$refs.timerbtn.stop(); //停止倒计时
     }
          });
        },
      }
    });

    总结

    以上所述是小编给大家介绍的Vue中添加手机验证码组件功能操作方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对考高分网网站的支持!

    转载请注明:文章转载自 www.mshxw.com
    本文地址:https://www.mshxw.com/it/83513.html
    我们一直用心在做
    关于我们 文章归档 网站地图 联系我们

    版权所有 (c)2021-2022 MSHXW.COM

    ICP备案号:晋ICP备2021003244-6号