博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
验证码倒计时
阅读量:7114 次
发布时间:2019-06-28

本文共 1455 字,大约阅读时间需要 4 分钟。

  实际开发中,验证码的验证,现在各大网站都是必须的,什么手机验证码验证,邮箱验证等。今天遇到一个例子,特地记录一下。

     模拟HTML结构,实际要复杂的多。

  HTML结构很简单,就是两个按钮,有不同的id,如下:

  为了简化dom操作,我们引入jQuery,js 代码如下:

function settime(val,verify_type,setTimeNumber) {    if (setTimeNumber== 0) {        val.removeAttribute("disabled");        val.innerHTML = verify_type;        setTimeNumber= setTimeNumber
; } else { val.setAttribute("disabled", true);  val.innerHTML = "重新发送(" + setTimeNumber + ")"; setTimeNumber--; setTimeout(function() {
settime(val,verify_type,setTimeNumber); },1000); } } $("#btn").click(function(){ settime(this,"手机验证码",10); }) $("#btn2").click(function(){ settime(this,"邮箱验证码",20); })

  这里对函数稍稍的封装了一下,因为我们想在实际的开发中,只要是验证码的业务,都用一套Js,所以,封装少不了,当然我这里是简单的,有更好的封装方法,可以评论留言,我们相互学习。我把验证的类型和验证的时间分开写,作为参数传入,目的就是在调用的时候,对不同的对象采用同一种方法,只要传入不同的参数就可以实现,这就是js中的封装和多态的思想。

  代码中,用了if的判断,只要 setTimeNumber 的值是0,那么就是倒计时结束,我们就让这个按钮可以点击了,移出“disabled”的属性。val.removeAttribute("disabled");

如果不是为0的值,(当然,在传入的时候,必须是正整数,不过我们也可以在函数里判断,如果传入的参数不是正整数,就return 等处理。),我们就让这个值减一,调用定时器来处理,让定时器,调用这个函数,知道setTimeNumber为0,同时在倒计时的时候,按钮是不可点击的,因此,给它要添加disabled的属性。

每日一句:Today is a long time away from the chaotic 1970s, but Wolverine seems no less relevant in the age of President Trump. As Alex Godfrey of Empire magazine wrote: “Wolverine was created in a dark, uncertain time of political upheaval. We don’t want him going anywhere.

翻译:今天离混乱的上世纪70年代已经很远了,但金刚狼似乎仍和特朗普的总统时代息息相关。正如《帝国》杂志的亚历克斯·戈弗雷所写的那样:“金刚狼创造于一个黑暗、动荡的政治巨变年代。我们不想让他远离。”

 

转载地址:http://bmmhl.baihongyu.com/

你可能感兴趣的文章
thinkPHP5.0的学习研究【基础】
查看>>
《WPF程序设计指南》读书笔记——第9章 路由输入事件
查看>>
Codeforces GoodBye2015 New Year and Three Musketeers Codeforces 611E(贪心)
查看>>
【java JVM】JVM中类的加载,加载class文件的原理机制
查看>>
Android数据存储——2.文件存储_A_文本文件
查看>>
Tips_关闭按钮的简单实现 && Felx实现水平垂直居中
查看>>
Redis 入门第一发
查看>>
sql server存储过程语法
查看>>
用jq中jSignature做手动签名
查看>>
使用NPOI读取Excel出错
查看>>
Reverse Nodes in k-Group
查看>>
libevent(一)定时器Demo
查看>>
(4)Django框架学习-Model篇
查看>>
Python 中文编码
查看>>
BigDecimal舍入模式使用及建议
查看>>
Tornado初探
查看>>
HDU5690: All X(大数取模,同余)
查看>>
HDU2544:最短路(最短路)
查看>>
js ==与===区别(两个等号与三个等号)
查看>>
小程序:最难点For的wx:key
查看>>