vue实现验证码按钮倒计时功能


Posted in Javascript onApril 10, 2018

本人最近开始尝试学习vue.js。想使用vue写一个小例子,就选择做验证码按钮倒计时功能。

    上网上搜了一下,也把他们的代码试了一下,自己出了很多问题。所以,需要写一篇基础入门的文章,避免后面人采坑。

   这是按照网上写的HTML页面

<div class="register-pannel" id ="register-pannel"> 
      <div class="register-l" align="center"> 
        <div class="input-group" style="width: 300px;"> 
          <input type="text" class="form-control" placeholder="邮箱/手机号/用户名" style="height: 40px;" /> 
          <span class="glyphicon glyphicon-user form-control-feedback" aria-hidden="true" /> 
        </div> 
        <br /> 
        <div class="input-group" style="width: 300px;"> 
          <input type="text" class="form-control" placeholder="密码" style="height: 40px;" /> 
          <span class="glyphicon glyphicon-lock form-control-feedback" /> 
        </div> 
        <br /> 
        <div class="input-group" style="width: 300px;"> 
          <input type="text" class="form-control" placeholder="手机号" style="height: 40px;" /> 
          <span class="glyphicon glyphicon-phone form-control-feedback" /> 
        </div> 
        <br /> 
        <div class="input-group" style="width: 300px;"> 
            <span class="register-msg-btn" v-show="show" v-on:click="getCode">发送验证码</span> 
            <span class="register-msg-btn" v-show="!show">{{count}} s</span> 
          <input type="text" class="form-control" placeholder="验证码" style="float: right; height: 40px; width: 150px;" /> 
          <span class="glyphicon glyphicon-font form-control-feedback" /> 
        </div> 
        <br /> 
        <span class="btn-register">注册</span> 
      </div>

js写成

<script> 
<span style="white-space: pre;">      </span>data(){   
<span style="white-space: pre;">      </span>return {   
<span style="white-space: pre;">        </span>show: true,   
<span style="white-space: pre;">        </span>count: '',   
<span style="white-space: pre;">        </span>timer: null,   
<span style="white-space: pre;">      </span>}  
<span style="white-space: pre;">    </span>},  
<span style="white-space: pre;">    </span>methods:{   
<span style="white-space: pre;">      </span>getCode(){    
<span style="white-space: pre;">        </span>const TIME_COUNT = 60;    
<span style="white-space: pre;">        </span>if (!this.timer) {     
<span style="white-space: pre;">          </span>this.count = TIME_COUNT;     
<span style="white-space: pre;">          </span>this.show = false;     
<span style="white-space: pre;">          </span>this.timer = setInterval(() => {     
<span style="white-space: pre;">            </span>if (this.count > 0 && this.count <= TIME_COUNT) {      
<span style="white-space: pre;">              </span>this.count--;      
<span style="white-space: pre;">            </span>} else {      
<span style="white-space: pre;">              </span>this.show = true;      
<span style="white-space: pre;">              </span>clearInterval(this.timer);      
<span style="white-space: pre;">              </span>this.timer = null;      
<span style="white-space: pre;">            </span>}     
<span style="white-space: pre;">          </span>}, 1000)     
<span style="white-space: pre;">        </span>}   
<span style="white-space: pre;">      </span>}   
<span style="white-space: pre;">    </span>} 
</script>

发现浏览器一直报错Uncaught SyntaxError: Unexpected token {

所以按照官方文档的格式,把js的结构改成

<script> 
    new Vue({ 
      el:'.register-pannel',      
      data:{    
        show:true,   
        timer:null, 
        count:'' 
      },  
      methods:{   
        getCode(){ 
          this.show = false; 
          const TIME_COUNT = 60;    
          if (!this.timer) {     
            this.count = TIME_COUNT;     
            this.show = false;     
            this.timer = setInterval(() => {     
              if (this.count > 0 && this.count <= TIME_COUNT) {      
                this.count--;      
              } else {      
                this.show = true;      
                clearInterval(this.timer);      
                this.timer = null;      
              }     
            }, 1000)     
          }   
        }   
      } 
    }); 
    </script>

于是格式是没有问题了,但是样式并没有生效。变成了另一个样子。

vue实现验证码按钮倒计时功能

上网上搜了很多。

有说是js引用顺序的问题。

有说是将js写进window.onload的。试了一下,发现都不对。

后来,在官方文档中发现了el属性:为实例提供挂载元素。值可以是 CSS 选择符,或实际 HTML 元素,或返回 HTML 元素的函数。

所以改成

<script>
 new Vue({
  el:'.register-pannel', //注册div的class 
  data:{   
  show:true,  
  timer:null,
  count:''
  }, 
  methods:{  
  getCode(){
   this.show = false;
   const TIME_COUNT = 60;   
   if (!this.timer) {    
   this.count = TIME_COUNT;    
   this.show = false;    
   this.timer = setInterval(() => {    
    if (this.count > 0 && this.count <= TIME_COUNT) {     
    this.count--;     
    } else {     
    this.show = true;     
    clearInterval(this.timer);     
    this.timer = null;     
    }    
   }, 1000)    
   }  
  }  
  }
 });
</script>

效果就出来了。

vue实现验证码按钮倒计时功能

总结

以上所述是小编给大家介绍vue实现验证码按钮倒计时功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JavaScript获取图片的原始尺寸以宽度为例
May 04 Javascript
14款经典网页图片和文字特效的jQuery插件-前端开发必备
Aug 25 Javascript
jQuery简单实现两级下拉菜单效果代码
Sep 15 Javascript
简单介绍JavaScript数据类型之隐式类型转换
Dec 28 Javascript
jquery 动态增加,减少input表单的简单方法(必看)
Oct 12 Javascript
Jquery循环截取字符串的方法(多出的字符串处理成&quot;...&quot;)
Nov 28 Javascript
JS针对Array的各种操作汇总
Nov 29 Javascript
jquery插件开发之选项卡制作详解
Aug 30 jQuery
JavaScript判断日期时间差的实例代码
Mar 01 Javascript
H5+C3+JS实现五子棋游戏(AI篇)
May 28 Javascript
node版本管理工具n包使用教程详解
Nov 09 Javascript
vue-cli3+typescript初体验小结
Feb 28 Javascript
vue 微信授权登录解决方案
Apr 10 #Javascript
详解给Vue2路由导航钩子和axios拦截器做个封装
Apr 10 #Javascript
详解webpack 打包文件体积过大解决方案(code splitting)
Apr 10 #Javascript
Angular CLI在Angular项目中如何使用scss详解
Apr 10 #Javascript
vue2.0+koa2+mongodb实现注册登录
Apr 10 #Javascript
bing Map 在vue项目中的使用详解
Apr 09 #Javascript
详解Vue打包优化之code spliting
Apr 09 #Javascript
You might like
微信公众平台消息接口校验与消息接口响应实例
2014/12/23 PHP
php实现QQ空间获取当前用户的用户名并生成图片
2015/07/25 PHP
php防止网站被攻击的应急代码
2015/10/21 PHP
利用PHP如何写APP接口详解
2016/08/23 PHP
thinkPHP多语言切换设置方法详解
2016/11/11 PHP
laravel项目利用twemproxy部署redis集群的完整步骤
2018/05/11 PHP
40款非常棒的jQuery 插件和制作教程(系列一)
2011/10/26 Javascript
JQuery防止退格键网页后退的实现代码
2012/03/23 Javascript
js DOM 元素ID就是全局变量
2012/09/20 Javascript
JavaScript避免代码的重复执行经验技巧分享
2014/04/17 Javascript
Javascript实现多彩雪花从天降散落效果的方法
2015/02/02 Javascript
jQuery实现防止提交按钮被双击的方法
2015/03/24 Javascript
js改变css样式的三种方法推荐
2016/06/28 Javascript
详解Angular5 服务端渲染实战
2018/01/04 Javascript
实战node静态文件服务器的示例代码
2018/03/08 Javascript
浅谈vue首屏加载优化
2018/06/28 Javascript
vue.js使用v-pre与v-html输出HTML操作示例
2018/07/07 Javascript
ES6 Iterator遍历器原理,应用场景及相关常用知识拓展详解
2020/02/15 Javascript
js实现简单的贪吃蛇游戏
2020/04/23 Javascript
vue用elementui写form表单时,在label里添加空格操作
2020/08/13 Javascript
python2.7实现爬虫网页数据
2018/05/25 Python
在Python中实现shuffle给列表洗牌
2018/11/08 Python
在python中使用with打开多个文件的方法
2019/01/07 Python
python实现小球弹跳效果
2019/05/10 Python
python实现鸢尾花三种聚类算法(K-means,AGNES,DBScan)
2019/06/27 Python
Python利用多线程同步锁实现多窗口订票系统(推荐)
2019/12/22 Python
pytorch实现Tensor变量之间的转换
2020/02/17 Python
python爬虫学习笔记之pyquery模块基本用法详解
2020/04/09 Python
Willer台湾:日本高速巴士/夜行巴士预约
2017/07/09 全球购物
美国知名的旅游网站:OneTravel
2018/10/09 全球购物
初一地理教学反思
2014/01/16 职场文书
上海世博会志愿者口号
2014/06/17 职场文书
建议书格式
2015/02/04 职场文书
2015年护士节慰问信
2015/03/23 职场文书
JavaScript与JQuery框架基础入门教程
2021/07/15 Javascript
CSS 一行代码实现头像与国旗的融合
2021/10/24 HTML / CSS