JS自动倒计时30秒后按钮才可用(两种场景)


Posted in Javascript onAugust 31, 2015

展示效果图:

JS自动倒计时30秒后按钮才可用(两种场景)

WEB开发中经常会用到倒计时来限制用户对表单的操作,比如希望用户在一定时间内看完相关协议信息才允许用户继续下一步操作,又比如在收取手机验证码时允许用户在一定时间过后(未收到验证码的情况下)再次获取验证码。那么今天我来给大家介绍下如何使用Javascript来实现这一简单应用。

    查看演示 下载源码

应用场景1:用户注册时阅读完相关协议信息后才能激活按钮

某些网站注册时要求用户同意所谓的用户协议之类的信息,如果协议内容非常重要,有些网站会要求新注册的用户一定要阅读完相关协议信息才能激活下一步按钮提交表单。为了让用户能阅读完协议信息(实际用户有没有真正阅读咱不知道),开发者会设计一个倒计时比如30秒,30秒过后,表单提交按钮才会激活生效,下面来看具体如何实现。

<form action="https://3water.com/" method="post" name="agree"> 
 <input type="submit" class="button" value="请认真查看<服务条款和声明> ()" name="agreeb"> 
</form>

假设有上面这样一个表单,表单的其他部分我们省略,只有一个提交按钮,初始时按钮不可用,当显示30秒倒计时结束后,按钮就会显示“我同意”,并且可以点击激活。

我们用原生的js来实现这一效果:

<script> 
var secs = ; 
document.agree.agreeb.disabled=true; 
for(var i=;i<=secs;i++) { 
 window.setTimeout("update(" + i + ")", i * ); 
} 
function update(num) { 
 if(num == secs) { 
 document.agree.agreeb.value =" 我 同 意 "; 
 document.agree.agreeb.disabled=false; 
 } 
 else { 
 var printnr = secs-num; 
 document.agree.agreeb.value = "请认真查看<服务条款和声明> (" + printnr +")"; 
 } 
} 
</script>

我们设置时间为30秒,当然你也可以设置你想要的时间,将按钮禁用,也就是不可点击,然后循环30秒,通过window.setTimeout调用update()函数,将当前秒与倒计时对比,如果已经倒计时完成则显示“我同意”,并激活按钮。

应用场景2:用户激活短信通道向用户手机发送验证码短信以验明正身

很多网站在验证用户身份的时候需要提高用户信息的安全性,这样就会与用户手机绑定,于是就会向用户手机发送验证码信息,如果用户填写了正确的验证码提交后台,那么操作才会成功。而发送验证码也可能由于各种原因有发送不成功的情况,又不能让用户不停点击发送。如此开发者使用倒计时来处理这类问题,用户激活短信后,如果30秒后未收到验证码短信则可以再允许点击发送短信。

<form action="https://3water.com/" method="post" name="myform"> 
 <input type="button" class="button" value="获取手机验证码" name="phone" onclick="showtime()"> 
</form>

上面的表单在按钮上添加了一个onclick事件,调用了showtime()函数。

<script> 
function showtime(t){ 
 document.myform.phone.disabled=true; 
 for(i=;i<=t;i++) { 
 window.setTimeout("update_p(" + i + ","+t+")", i * ); 
 } 
 
} 
function update_p(num,t) { 
 if(num == t) { 
 document.myform.phone.value =" 重新发送 "; 
 document.myform.phone.disabled=false; 
 } 
 else { 
 printnr = t-num; 
 document.myform.phone.value = " (" + printnr +")秒后重新发送"; 
 } 
} 
</script>

和场景1一样,当点击按钮后,按钮状态为禁用,通过调用window.setTimeoutupdate_p()显示倒计时,当倒计时完成后,按钮显示“重新发送”,这时按钮状态为可用。

以上通过两种场景给大家展示了js实现自动倒计时30秒后按钮才可用,希望对大家有所帮助。

Javascript 相关文章推荐
javascript 处理null及null值示例
Jun 09 Javascript
jquery实现的树形目录实例
Jun 26 Javascript
javascript 继承学习心得总结
Mar 17 Javascript
如何检测JavaScript的各种类型
Jul 30 Javascript
Google 地图API资料整理及详细介绍
Aug 06 Javascript
浅谈React + Webpack 构建打包优化
Jan 23 Javascript
尝试自己动手用react来写一个分页组件(小结)
Feb 09 Javascript
vue中设置height:100%无效的问题及解决方法
Jul 27 Javascript
使用taro开发微信小程序遇到的坑总结
Apr 08 Javascript
微信小程序实现上传word、txt、Excel、PPT等文件功能
May 23 Javascript
vue 解决setTimeOut和setInterval函数无效报错的问题
Jul 30 Javascript
JQuery Ajax如何实现注册检测用户名
Sep 25 jQuery
js实现黑色简易的滑动门网页tab选项卡效果
Aug 31 #Javascript
jquery实现点击变换导航样式的方法
Aug 31 #Javascript
jQuery实现灰蓝风格标准二级下拉菜单效果代码
Aug 31 #Javascript
js实现TAB切换对应不同颜色的代码
Aug 31 #Javascript
Bootstrap的图片轮播示例代码
Aug 31 #Javascript
jQuery实现鼠标滑过点击事件音效试听
Aug 31 #Javascript
js实现仿百度风云榜可重复多次调用的TAB切换选项卡效果
Aug 31 #Javascript
You might like
php注入实例
2006/10/09 PHP
php 获取SWF动画截图示例代码
2014/02/10 PHP
几道坑人的PHP面试题 试试看看你会不会也中招
2014/08/19 PHP
php中文字符串截取方法实例总结
2014/09/30 PHP
php文件包含目录配置open_basedir的使用与性能详解
2017/04/03 PHP
PHP使用Nginx实现反向代理
2017/09/20 PHP
你可能不再需要JQUERY
2021/03/09 Javascript
javascript对象的property和prototype是这样一种关系
2007/03/24 Javascript
根据出生日期自动取得星座的js代码
2010/07/20 Javascript
js 获取计算后的样式写法及注意事项
2013/02/25 Javascript
jQuery下实现等待指定元素加载完毕(可改成纯js版)
2013/07/11 Javascript
js图片实时加载提供网页打开速度
2014/09/11 Javascript
js实现class样式的修改、添加及删除的方法
2015/01/20 Javascript
javascript巧用eval函数组装表单输入项为json对象的方法
2015/11/25 Javascript
js 奇葩技巧之隐藏代码
2017/08/11 Javascript
js数组实现权重概率分配
2017/09/12 Javascript
Vue封装全局过滤器Filters的步骤
2020/09/16 Javascript
vue 函数调用加括号与不加括号的区别
2020/10/29 Javascript
[05:59]2018DOTA2国际邀请赛寻真——只为胜利的Secret
2018/08/13 DOTA
[01:00:11]DOTA2-DPC中国联赛 正赛 CDEC vs DLG BO3 第一场 2月7日
2021/03/11 DOTA
python2和python3在处理字符串上的区别详解
2019/05/29 Python
tensorflow之并行读入数据详解
2020/02/05 Python
Keras - GPU ID 和显存占用设定步骤
2020/06/22 Python
社区版pycharm创建django项目的方法(pycharm的newproject左侧没有项目选项)
2020/09/23 Python
pytorch简介
2020/11/11 Python
YSL圣罗兰美妆美国官网:Yves Saint Lauret US
2016/11/21 全球购物
亚洲最大旅游体验平台:KKday
2017/10/21 全球购物
迷你西餐厅创业计划书范文
2013/12/31 职场文书
总经理文秘岗位职责
2014/02/03 职场文书
优秀管理者获奖感言
2014/02/17 职场文书
《秋姑娘的信》教学反思
2014/02/28 职场文书
函授毕业生自我鉴定范文
2014/03/25 职场文书
公司经理任命书
2014/06/05 职场文书
优秀员工事迹材料
2014/12/20 职场文书
计算机教师工作总结
2015/08/13 职场文书
聊聊配置 Nginx 访问与错误日志的问题
2022/05/25 Servers