Vue 短信验证码组件开发详解


Posted in Javascript onFebruary 14, 2017

Vue.js(读音 /vjuː/, 类似于 view)是一个构建数据驱动的 web 界面的库。Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。

Vue.js 自身不是一个全能框架——它只聚焦于视图层。因此它非常容易学习,非常容易与其它库或已有项目整合。另一方面,在与相关工具和支持库一起使用时,Vue.js 也能完美地驱动复杂的单页应用。

摘要:

1、该组件基于Vue 2.1.X版本;

1、 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 后重获取' : '获取验证码';
    }
  }
});

2、使用方式:

<timer-btn ref="timerbtn" class="btn btn-default" v-on:run="sendCode" 
:disabled="disabled" :second="60"></timer-btn>

disabled 建议不要绑定,我们可以通过调用组件的setDisabled方法来切换按钮可用状态;

second 初始值60s 没特别值可以不绑定;

所以我们可以在HTML页面这样:

<timer-btn ref="timerbtn" class="btn btn-default" v-on:run="sendCode" ></timer-btn>

JS这样:

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 短信验证码组件开发详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
HTML 自动伸缩的表格Table js实现
Apr 01 Javascript
jquery中动态效果小结
Dec 16 Javascript
学习javascript,实现插入排序实现代码
Jul 31 Javascript
通过node-mysql搭建Windows+Node.js+MySQL环境的教程
Mar 01 Javascript
浅析jQuery Ajax通用js封装
Jun 22 Javascript
jquery日历插件e-calendar升级版
Nov 10 Javascript
详解Angular 4.x NgTemplateOutlet
May 24 Javascript
JS简单获得节点元素的方法示例
Feb 10 Javascript
详解ng-alain动态表单SF表单项设置必填和正则校验
Jun 11 Javascript
对layui初始化列表的CheckBox属性详解
Sep 13 Javascript
vue+elementUI实现简单日历功能
Sep 24 Javascript
node.js通过Sequelize 连接MySQL的方法
Dec 28 Javascript
JS去除字符串中空格的方法
Feb 14 #Javascript
Node.js与Sails redis组件的使用教程
Feb 14 #Javascript
JS表单验证方法实例小结【电话、身份证号、Email、中文、特殊字符、身份证号等】
Feb 14 #Javascript
canvas实现十二星座星空图
Feb 14 #Javascript
JavaScript省市级联下拉菜单实例
Feb 14 #Javascript
jqGrid翻页时数据选中丢失问题的解决办法
Feb 13 #Javascript
jQuery实现用户输入自动完成功能
Feb 13 #Javascript
You might like
php 带逗号千位符数字的处理方法
2012/01/10 PHP
PHP序列号生成函数和字符串替换函数代码
2012/06/07 PHP
php set_time_limit()函数的使用详解
2013/06/05 PHP
PHP检测字符串是否为UTF8编码的常用方法
2014/11/21 PHP
PHP使用CURL实现多线程抓取网页
2015/04/30 PHP
PHP实用小技巧之调用录像的方法
2019/12/05 PHP
取得传值的函数
2006/10/27 Javascript
Web开发者必备的12款超赞jQuery插件
2010/12/03 Javascript
jQuery拖动图片删除示例
2013/05/10 Javascript
js 控制页面跳转的5种方法
2013/09/09 Javascript
使用jQuery解决IE与FireFox下createElement方法的差异
2013/11/14 Javascript
Google Maps API地图应用示例分享
2014/10/23 Javascript
Node.js的Mongodb使用实例
2016/12/30 Javascript
Angular4学习笔记之实现绑定和分包
2017/08/01 Javascript
jQuery实现定时隐藏对话框的方法分析
2018/02/12 jQuery
对Vue- 动态元素属性及v-bind和v-model的区别详解
2018/08/27 Javascript
vue实现的双向数据绑定操作示例
2018/12/04 Javascript
详解基于mpvue微信小程序下载远程图片到本地解决思路
2019/05/16 Javascript
解决vue项目中遇到 Cannot find module ‘chalk‘ 报错的问题
2020/11/05 Javascript
[02:57]DOTA2亚洲邀请赛小组赛第四日 赛事回顾
2015/02/02 DOTA
[00:12]DAC2018 天才少年转战三号位,他的SOLO是否仍如昔日般强大?
2018/04/06 DOTA
详解Python实现按任意键继续/退出的功能
2016/08/19 Python
Falsk 与 Django 过滤器的使用与区别详解
2019/06/04 Python
Django高并发负载均衡实现原理详解
2020/04/04 Python
经典优秀毕业生求职信范文分享
2013/12/18 职场文书
大学生村官心得体会范文
2014/01/04 职场文书
青年创业培训欢迎词
2014/01/10 职场文书
员工三分钟演讲稿
2014/08/19 职场文书
基层党组织整改方案
2014/10/25 职场文书
交通事故死亡赔偿协议书
2014/12/03 职场文书
2015最新婚礼司仪主持词
2015/06/30 职场文书
合作合同协议书
2016/03/21 职场文书
传单、海报早OUT了,另类传单营销方案送给你!
2019/07/15 职场文书
Java面试题冲刺第十九天--数据库(4)
2021/08/07 Java/Android
nginx常用配置conf的示例代码详解
2022/03/21 Servers
java实现面板之间切换功能
2022/06/10 Java/Android