这篇文章主要为大家展示了“JavaScript如何仿京东实现秒杀倒计时”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“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='h2'></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如何仿京东实现秒杀倒计时”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。