功能介绍:
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秒杀倒计时内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!