jQuery实现发送验证码控制按钮禁用功能
更新时间:2021年07月24日 10:53:35 作者:野草闲花逢春生
最近接到新需求,需要实现一个点击发送验证码之后,按钮禁用,在5秒之后取消禁用,看似需求很简单,实现起来还真的好好动动脑筋,下面小编把jquery控制按钮禁用核心代码分享给大家,需要的朋友参考下吧
需求效果:点击发送验证码之后,按钮禁用,5秒之后取消禁用。
效果图如下:
点击发送之后禁用按钮
5秒之后取消禁用,重新发送
代码如下:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> </head> <body> <input type="text"> <input type="button" value="发送"> <script src="js/jquery-1.12.4.min.js"></script> <script> // 获取元素 var $btn = $("input:button") // 添加按钮的点击事件 $btn.click(function () { // 定义一个变量存储时间的数字 var n = 5; // 让按钮被禁用 // 替换按钮的文字内容 $(this).prop("disabled",true).val(n + "s 后重新发送") // 每隔 1s 更改倒计时内容 // 通过定时器进行每隔 1s 减时间效果 var timer = setInterval(() => { n--; // 文字内容发生变化 // 定时器内部的this指向的默认为 window $(this).val(n + "s 后重新发送") // 判断如果时间到了 0 ,就要停止定时器 if (n <= 0) { clearInterval(timer) // 5s 结束后,需要让文字恢复 发送 // 让按钮取消禁用 $(this).val("重新发送").prop("disabled",false) } },1000) }) </script> </body> </html>
到此这篇关于jQuery实现发送验证码控制按钮禁用功能的文章就介绍到这了,更多相关jquery控制按钮禁用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Jquery中offset()和position()的区别分析
这篇文章主要介绍了Jquery中offset()和position()的区别,实例分析了offset()与position()的使用的技巧与区别,具有一定参考借鉴价值,需要的朋友可以参考下2015-02-02
最新评论