update: 倒计时举例

This commit is contained in:
qianguyihao 2020-05-14 20:46:17 +08:00
parent f76e642400
commit 5457093cfa

View File

@ -170,9 +170,9 @@ function formatDate() {
Date对象 还有如下方法 Date对象 还有如下方法
- `getTime()` 获取日期对象的**时间戳**单位毫秒这个方法在实战开发中用得比较多 - `getTime()` 获取日期对象的**时间戳**单位毫秒这个方法在实战开发中用得比较多但还有比它更常用的写法我们往下看
啥叫时间戳接下来我们解释一下 啥叫时间戳我们先来解释这个概念
### 时间戳的定义和作用 ### 时间戳的定义和作用
@ -180,7 +180,7 @@ Date对象 还有如下方法:
计算机底层在保存时间时使用的都是时间戳时间戳的存在就是为了**统一**时间的单位 计算机底层在保存时间时使用的都是时间戳时间戳的存在就是为了**统一**时间的单位
我们经常会利用时间戳来计算时间因为它更精确 我们经常会利用时间戳来计算时间因为它更精确而且在实战开发中接口返回给前端的日期数据都是以时间戳的形式
我们再来看下面这样的代码 我们再来看下面这样的代码
@ -210,7 +210,7 @@ Date对象 还有如下方法:
var date2 = new Date(); var date2 = new Date();
// 方式二:获取 Date 对象的时间戳 // 方式二:获取 Date 对象的时间戳(较常用的写法)
console.log(date2.getTime()); // 打印结果举例1589448165370 console.log(date2.getTime()); // 打印结果举例1589448165370
// 方式三:获取 Date 对象的时间戳 // 方式三:获取 Date 对象的时间戳
@ -226,11 +226,11 @@ Date对象 还有如下方法:
如果我们要获取**当前时间**的时间戳除了上面的三种方式之外还有另一种方式代码如下 如果我们要获取**当前时间**的时间戳除了上面的三种方式之外还有另一种方式代码如下
```js ```js
// 方式四:获取当前时间的时间戳 // 方式四:获取当前时间的时间戳(很常用的写法)
console.log(Date.now()); // 打印结果举例1589448165370 console.log(Date.now()); // 打印结果举例1589448165370
``` ```
上面这种方式用得也很多只不过`Date.now()`是H5标准中新增的特性如果你的项目需要兼容低版本的IE浏览器就不要用了这年头谁还用IE呢 上面这种方式用得也很多只不过`Date.now()`是H5标准中新增的特性如果你的项目需要兼容低版本的IE浏览器就不要用了这年头谁还用IE呢
### 利用时间戳检测代码的执行时间 ### 利用时间戳检测代码的执行时间
@ -304,7 +304,9 @@ Date对象 还有如下方法:
实现思路 实现思路
设置一个定时器每间隔1毫秒就自动刷新一次div的内容 - 设置一个定时器每间隔1毫秒就自动刷新一次div的内容
- 核心算法输入的时间戳减去当前的时间戳就是剩余时间即倒计时然后转换成时分秒
代码实现 代码实现
@ -312,7 +314,7 @@ Date对象 还有如下方法:
<!DOCTYPE html> <!DOCTYPE html>
<html> <html>
<head lang="en"> <head lang="en">
<meta charset="UTF-8"> <meta charset="UTF-8" />
<title></title> <title></title>
<style> <style>
div { div {
@ -320,7 +322,7 @@ Date对象 还有如下方法:
margin: 200px auto; margin: 200px auto;
color: red; color: red;
text-align: center; text-align: center;
font: 600 30px/30px "simsun"; font: 600 30px/30px 'simsun';
} }
</style> </style>
</head> </head>
@ -328,42 +330,48 @@ Date对象 还有如下方法:
<div></div> <div></div>
<script> <script>
var div = document.getElementsByTagName("div")[0]; var div = document.getElementsByTagName('div')[0];
var timer = setInterval(fn, 1);
function fn() { var timer = setInterval(() => {
var nowtime = new Date(); countDown('2022/02/03 11:20:00');
var future = new Date("2019/02/03 11:20:00"); }, 1);
var timeSum = future.getTime() - nowtime.getTime(); //获取时间差:发布会时间减去此刻的毫秒值
var day = parseInt(timeSum / 1000 / 60 / 60 / 24);
var hour = parseInt(timeSum / 1000 / 60 / 60 % 24);
var minu = parseInt(timeSum / 1000 / 60 % 60);
var sec = parseInt(timeSum / 1000 % 60);
var millsec = parseInt(timeSum % 1000);
//问题处理所有的时间小于10的时候在前面自动补0毫秒值要补双0比如如把 8 秒改成 08 秒) function countDown(myTime) {
day = day < 10 ? "0" + day : day; //day小于10吗如果小于就补0如果不小于就是day本身 var nowTime = new Date();
hour = hour < 10 ? "0" + hour : hour; var future = new Date(myTime);
minu = minu < 10 ? "0" + minu : minu; var timeSum = future.getTime() - nowTime.getTime(); //获取时间差:发布会时间减去此刻的毫秒值
sec = sec < 10 ? "0" + sec : sec;
var day = parseInt(timeSum / 1000 / 60 / 60 / 24); // 天
var hour = parseInt((timeSum / 1000 / 60 / 60) % 24); // 时
var minu = parseInt((timeSum / 1000 / 60) % 60); // 分
var sec = parseInt((timeSum / 1000) % 60); // 秒
var millsec = parseInt(timeSum % 1000); // 毫秒
//细节处理所有的时间小于10的时候在前面自动补0毫秒值要补双0比如如把 8 秒改成 08 秒)
day = day < 10 ? '0' + day : day; //day小于10吗如果小于就补0如果不小于就是day本身
hour = hour < 10 ? '0' + hour : hour;
minu = minu < 10 ? '0' + minu : minu;
sec = sec < 10 ? '0' + sec : sec;
if (millsec < 10) { if (millsec < 10) {
millsec = "00" + millsec; millsec = '00' + millsec;
} else if (millsec < 100) { } else if (millsec < 100) {
millsec = "0" + millsec; millsec = '0' + millsec;
} }
// console.log(day);
// console.log(parseInt(timeSum/1000/60/60/24)); // 兜底处理
if (timeSum < 0) { if (timeSum < 0) {
div.innerHTML = "距离苹果发布会还有00天00小时00分00秒000毫秒"; div.innerHTML = '距离苹果发布会还有00天00小时00分00秒000毫秒';
clearInterval(timer); clearInterval(timer);
return; return;
} }
div.innerHTML = "距离苹果发布会还有" + day + "天" + hour + "小时" + minu + "分" + sec + "秒" + millsec + "毫秒";
// 前端要显示的文案
div.innerHTML = '距离苹果发布会还有' + day + '天' + hour + '小时' + minu + '分' + sec + '秒' + millsec + '毫秒';
} }
</script> </script>
</body> </body>
</html> </html>
``` ```
实现效果 实现效果