JavaScript仿京东实现秒杀倒计时案例详解
更新时间:2022年03月08日 10:17:33 作者:一夕ξ
这篇文章主要为大家详细介绍了如何利用JavaScript实现京东秒杀倒计时效果,文中示例代码介绍的非常详细,感兴趣的小伙伴们可以参考一下
功能介绍:
1、这个倒计时是不断变化的,因此需要定时器来自动变化(setInterval)
2、三个黑色的盒子,分别存放时、分秒
3、三个盒子利用innerHTML存入倒计时
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <style> div { background-color: black; width: 50px; height: 50px; margin-left: 20px; float: left; color: white; font-size: 20px; text-align: center; line-height: 50px; } </style> </head> <body> <div class='h1'></div> <div class='m'></div> <div class='s1'></div> <script> //把时间放到div中去 var div = document.querySelectorAll('div') var timer1 = setInterval(function() { var date1 = new Date(2022, 3, 2, 18, 40, 0); //获得到点截至时间距离标准时间的毫秒数 var date2 = new Date(); //获得目前时间距离准时间的毫秒数 var date = (date1 - date2) / 1000; //用到点时间的毫秒数减去现在时间的毫秒数,必须先化为秒单位,之后再进行转换 var h = parseInt((date / 60 / 60) % 24); //小时 var m = parseInt((date / 60) % 60); //分钟 var s = parseInt(date % 60); //秒 一定要包含在这个函数中,因为是间隔1秒就要重新算一遍,需要提高准确率的话,把秒数减少(刷新间隔) div[2].innerHTML = s div[1].innerHTML = m div[0].innerHTML = h }, [1]) </script> </body> </html>
改进:
<script> //把时间放到div中去 var div = document.querySelectorAll('div') var timer1 = setInterval(fn, [1000]) var date1 = new Date(2022, 3, 2, 18, 40, 0); var date2 = new Date(); var date = (date1 - date2) / 1000; var h = parseInt((date / 60 / 60) % 24); var m = parseInt((date / 60) % 60); var s = parseInt(date % 60); div[2].innerHTML = s div[1].innerHTML = m div[0].innerHTML = h //解决刚刷新,数字不显示的问题 function fn() { var date1 = new Date(2022, 3, 2, 18, 40, 0); //获得到点截至时间距离标准时间的毫秒数 var date2 = new Date(); //获得目前时间距离准时间的毫秒数 var date = (date1 - date2) / 1000; //用到点时间的毫秒数减去现在时间的毫秒数,必须先化为秒单位,之后再进行转换 var h = parseInt((date / 60 / 60) % 24); //小时 var m = parseInt((date / 60) % 60); //分钟 var s = parseInt(date % 60); //秒 一定要包含在这个函数中(最好是封装一个函数),因为是间隔1秒就要重新算一遍,需要提高准确率的话,把秒数减少(刷新间隔).如果间隔比较大的话,一刷新页面,会产生空白。解决方法就是,在未调用这个函数前,先把时间放入到div盒子中 div[2].innerHTML = s div[1].innerHTML = m div[0].innerHTML = h } </script>
添加停止倒计时按钮:
<button>停止倒计时</button> var btn = document.querySelector('button') btn.addEventListener('click', function() { clearInterval(timer1) })
到此这篇关于JavaScript仿京东实现秒杀倒计时案例详解的文章就介绍到这了,更多相关JavaScript秒杀倒计时内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
使用UrlConnection实现后台模拟http请求的简单实例
这篇文章主要介绍了使用UrlConnection实现后台模拟http请求的简单实例的相关资料,需要的朋友可以参考下2017-01-01JavaScript回调(callback)函数概念自我理解及示例
此文适合JavaScript入门级选手阅读,在JavaScript里什么叫Callback“回调函数”,把方法b当做一个参数传递个方法a,当方法a执行完后执行另外一个指定函数(这里是b函数),感兴趣的朋友可以了解下哈2013-07-07
最新评论