广告
返回顶部
首页 > 资讯 > 精选 >Vue怎么添加手机验证码组件功能
  • 225
分享到

Vue怎么添加手机验证码组件功能

2023-07-04 10:07:20 225人浏览 薄情痞子
摘要

本篇内容主要讲解“Vue怎么添加手机验证码组件功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue怎么添加手机验证码组件功能”吧!什么是组件:组件是vue.js最强大的功能之一。组件可以扩展

本篇内容主要讲解“Vue怎么添加手机验证码组件功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue怎么添加手机验证码组件功能”吧!

什么是组件:

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

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

<template > <div>  <div class="bind-phone-box">   <div class="phone-title">绑定手机</div>   <div class="phone-content" v-on:click.stop="fillContent">    <input v-model="phoneNum" class="phone-num" type="text" placeholder="请输入手机号码">    <div class="verify-box clearfix">     <input class="verify-num" v-model="verifyNum" type="text" placeholder="请输入验证码"><input v-on:click="sendSmsCode" class="verify-btn" type="button" v-model="btnContent" v-bind="{'disabled':disabled}">    </div>   </div>   <div class="phone-submit clearfix">    <input class="submit-cancel" type="button" value="取消">    <input class="submit-confirm" v-on:click.stop="verificationCode" type="button" value="确定">   </div>  </div> </div></template>

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

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

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

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

<li class="mui-table-view-cell phone-li">   <span v-on:click="verifyPhone" class="mui-navigate-right"><span>手机号<span class="necessary">*</span></span></span>    <!-- 手机验证码 -->  <div class="shade" v-show="verifyShow" v-on:click="verifyPhone">    <!-- 手机验证码子组件 -->    <phoneVerify></phoneVerify>   </div>  </li>

通过控制 父div 的显示状态来控制子组件的显示状态,

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

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

<script> // 引入弹窗组件 import { Toast } from 'mint-ui'; export default {  data(){   return {    phoneNum:"", //手机号    verifyNum:"", //验证码    btnContent:"获取验证码", //获取验证码按钮内文字    time:0, //发送验证码间隔时间    disabled:false //按钮状态   }  },  created(){  },  methods:{   // 获取验证码   sendSmsCode(){    var reg=11&& /^((13|14|15|17|18)[0-9]{1}\d{8})$/;//手机号正则验证    var phoneNum = this.phoneNum;    if(!phoneNum){//未输入手机号     Toast("请输入手机号码");     return;    }    if(!reg.test(phoneNum)){//手机号不合法     Toast("您输入的手机号码不合法,请重新输入");    }    this.time = 60;    this.timer();    // 获取验证码请求    var url = 'Http://bosstan.asuscomm.com/api/common/sendSmsCode';    this.$http.post(url,{username:phoneNum},{emulateJSON:true}).then((response)=>{     console.log(response.body);    });   },   timer(){    if(this.time>0){     this.time--;     this.btnContent = this.time+"s后重新获取";     this.disabled = true;     var timer = setTimeout(this.timer,1000);    }else if(this.time == 0){     this.btnContent = "获取验证码";     clearTimeout(timer);     this.disabled = false;    }   },   // 验证验证码   verificationCode(){    var phoneNum = this.phoneNum;//手机号    var verifyNum = this.verifyNum;//验证码    var url = 'http://bosstan.asuscomm.com/api/common/verificationCode';    this.$http.post(url,{     username:phoneNum,     code:verifyNum    },{     emulateJSON:true    }).then((response)=>{     console.log(response.body);    });   },   fillContent(){    // console.log("fillContent");   }  } }</script>

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

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

Vue.component('timerBtn',{  template: '<button v-on:click="run" :disabled="disabled || time > 0">{{ text }}</button>',  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 后重获取' : '获取验证码';    }  }});
<timer-btn ref="timerbtn" class="btn btn-default" v-on:run="sendCode" ></timer-btn>
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是什么

Vue是一套用于构建用户界面的渐进式javascript框架,Vue与其它大型框架的区别是,使用Vue可以自底向上逐层应用,其核心库只关注视图层,方便与第三方库和项目整合,且使用Vue可以采用单文件组件和Vue生态系统支持的库开发复杂的单页应用。

到此,相信大家对“Vue怎么添加手机验证码组件功能”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: Vue怎么添加手机验证码组件功能

本文链接: https://www.lsjlt.com/news/344377.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Vue怎么添加手机验证码组件功能
    本篇内容主要讲解“Vue怎么添加手机验证码组件功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue怎么添加手机验证码组件功能”吧!什么是组件:组件是Vue.js最强大的功能之一。组件可以扩展...
    99+
    2023-07-04
  • Vue中如何添加手机验证码组件功能
    这篇文章主要介绍Vue中如何添加手机验证码组件功能,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!什么是组件:组件是Vue.js最强大的功能之一。组件可以扩展HTML元素,封装可重用的...
    99+
    2022-10-19
  • vue验证码组件怎么使用
    这篇文章主要讲解了“vue验证码组件怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue验证码组件怎么使用”吧!代码如下:<template&...
    99+
    2022-10-19
  • vue怎么实现手机验证码登录
    这篇文章主要介绍“vue怎么实现手机验证码登录”,在日常操作中,相信很多人在vue怎么实现手机验证码登录问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue怎么实现手机验证码登录”的疑惑有所帮助!接下来,请跟...
    99+
    2023-06-25
  • vue中如何实现手机号和邮箱正则验证以及60s发送验证码功能
    这篇文章将为大家详细讲解有关vue中如何实现手机号和邮箱正则验证以及60s发送验证码功能,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。写一个简单的验证,本来前面用的组件,...
    99+
    2022-10-19
  • PHP怎么实现基于梦网云的手机短信验证码功能
    这篇“PHP怎么实现基于梦网云的手机短信验证码功能”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“PHP怎么实现基于梦网云的手...
    99+
    2023-07-05
  • vue怎么实现验证码60秒倒计时功能
    本文小编为大家详细介绍“vue怎么实现验证码60秒倒计时功能”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue怎么实现验证码60秒倒计时功能”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。html代码如下:&l...
    99+
    2023-07-04
  • Vue 中怎么实现一个短信验证码组件
    本篇文章给大家分享的是有关Vue 中怎么实现一个短信验证码组件,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1、 Vue 组件代码如下:Vue...
    99+
    2022-10-19
  • PHP怎么实现随机数字、字母的验证码功能
    本篇内容主要讲解“PHP怎么实现随机数字、字母的验证码功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PHP怎么实现随机数字、字母的验证码功能”吧!废话不多说,直接上代码:1、classgd....
    99+
    2023-06-04
  • Vue怎么实现简易注册页面和发送验证码功能
    本篇内容介绍了“Vue怎么实现简易注册页面和发送验证码功能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. 效果展示2. 增强版验证码及邮...
    99+
    2023-06-21
  • 怎么在Android中利用控件实现一个验证码倒计时功能
    这期内容当中小编将会给大家带来有关怎么在Android中利用控件实现一个验证码倒计时功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。使用方式<com.landptf.view.CountDownM...
    99+
    2023-05-31
    android roi
  • 如何在SpringBoot中使用Shiro怎么实现一个邮件验证码登录功能
    如何在SpringBoot中使用Shiro怎么实现一个邮件验证码登录功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。导入依赖(pom.xml)  &...
    99+
    2023-06-06
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作