如何利用js来制作时间倒计时效果

  • 如何利用js来制作时间倒计时效果已关闭评论
  • 170 次浏览
  • A+
所属分类:Web前端
摘要

利用JavaScript函数做一个简单的倒计时

利用JavaScript函数做一个简单的倒计时

  <script>
        // 代码如下:
        function countDown(time) {
            var nowTime = +new Date(); // 返回的是当前时间总的毫秒数
            var inputTime = +new Date(time); // 返回的是用户输入时间总的毫秒数
            var times = (inputTime - nowTime) / 1000; // times是剩余时间总的秒数
            var d = parseInt(times / 60 / 60 / 24); // 把秒数转换成天数  (parselnt把得到的数转换为整数)
            d = d < 10 ? '0' + d : d;//这里为了让时间数好看一点,比如把4天改成04天,所以加了三元判定,下面也是如此;
            var h = parseInt(times / 60 / 60 % 24); //时
            h = h < 10 ? '0' + h : h;
            var m = parseInt(times / 60 % 60); //分
            m = m < 10 ? '0' + m : m;
            var s = parseInt(times % 60); // 秒
            s = s < 10 ? '0' + s : s;
            return d + '天' + h + '时' + m + '分' + s + '秒'; //返回函数计算出的值
        }
        console.log(countDown('这里输入你需要计算的时间')); //在控制台输出你输入时间与你电脑时间的差值就是倒计时;
        var date = new Date(); //获取你电脑当前的时间;
        console.log(date); //在控制台输出你当前电脑时间;
    </script>
 
1.核心算法:输入的时间减去现在的时间就是剩余的时间,即倒计时 ,但是不能拿着时分秒相减,比如 02 分减去22分,结果会是负数的,所以要转换为毫秒;
2.用时间戳来做。用户输入时间总的毫秒数减去现在时间的总的毫秒数,得到的就是剩余时间的毫秒数;
3.把剩余时间总的毫秒数转换为天、时、分、秒 (时间戳转换为时分秒)。