- A+
所属分类:Web前端
利用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.把剩余时间总的毫秒数转换为天、时、分、秒 (时间戳转换为时分秒)。