ZG前端学习第四天2020-10-31

周六自习 今日学习 利用js做一个简单的倒计时
演示效果:
在这里插入图片描述
核心思想:

  • 因为直接通过 new Date()获取的时间存在某些问题,所以通过使用输入时间和当前时间的时间戳来进行修改
  • 定时的显示时间的变化 所以用到setInterval()定时器来控制
  • 计算时的公式转换

d = parseInt(times/60/60/24);
h = parseInt(times/60/60%24);
m = parseInt(times/60%60);
s = parseInt(times%60)

代码展示:

<!DOCTYPE html>
<html lang="zh">
<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></title>
 <style>
  *{margin: 0;padding: 0;}
  ul{list-style: none;}
  ul li {float: left;margin: 10px 10px;font-size: 40px;text-align: center;background: #0000ff;line-height: 100px;width: 100px;height:100px;border:1px solid #000000;
  
 </style>
</head>
<body>
 <ul>
  <li class="box0">天</li>
  <li class="box1">时</li>
  <li class="box2">分</li>
  <li class="box3">秒</li>
 </ul>
<script type="text/javascript">
 var dd = document.querySelector('.box0');
 var hh = document.querySelector('.box1');
 var mm = document.querySelector('.box2');
 var ss = document.querySelector('.box3');
    var time = prompt('请输入你想输入的时间');
 // var time = '2020-10-31 12:00:00'
 var inputTime = + new Date (time);//获取输入时间的时间戳
 // console.log(m);
 // console.log(inputTime);
 countDown();//先调用这个函数 防止第一次刷新的时候出现空白
 setInterval(countDown,1000);
 
    function countDown (){
 var nowTime = + new Date();//获取当前时间的时间戳
 // console.log(nowTime);
 var times = (inputTime - nowTime) / 1000;//获得总的秒数
 var d = parseInt(times/60/60/24);//获取倒计时的天数
 d = d<10? '0'+d : d;
 dd.innerHTML = d + '天';
 var h = parseInt(times/60/60%24);//获取倒计时的小时
 h = h<10? '0'+h : h;
 hh.innerHTML = h + '时';
 var m = parseInt(times/60%60);//获取倒计时的分钟
 m = m<10? '0'+m : m;
 mm.innerHTML = m + '分';
 var s = parseInt(times%60);//获取倒计时的秒数
 s = s<10? '0'+s : s;
 ss.innerHTML = s + '秒';
 return d +'天' + h + '时' +m +'分' + s +'秒';
}
</script> 
</body>
</html>

以上代码可以添加if条件判断等语句进行更好的优化(比如输入时间的时间戳小于当前时间的时间戳或者所输入的月份 日份不合理的话可以设置显示框来提示用户所输入的时间是错误的)(当然对于电商等倒计时由管理给定默认时间就行)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值