<!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>
* {
margin: 0;
padding: 0;
}
.a {
width: 800px;
height: 200px;
margin: 100px auto 0;
border: 20px solid #000;
border-bottom: 0;
font-size: 50px;
text-align: center;
line-height: 200px;
color: rgb(238, 66, 66);
background-color: rgb(236, 250, 250);
border-image: linear-gradient(rgb(202, 243, 136), #F80) 20 20;
}
.bigDiv {
width: 800px;
height: 200px;
border: 20px solid #000;
margin: 0 auto;
border-image: linear-gradient(#F80, #2ED) 20 20;
display: flex;
justify-content: space-between;
}
.com {
text-align: center;
flex: 1;
font-size: 100px;
line-height: 200px;
color: rgb(238, 66, 66);
}
.div1 {
background-color: rgb(236, 241, 245);
}
.div2 {
border-left: 4px solid rgb(241, 183, 74);
border-right: 4px solid rgb(241, 183, 74);
background-color: rgb(245, 247, 233);
}
.div3 {
background-color: rgb(223, 241, 224);
}
</style>
</head>
<body>
<div class="a"></div>
<div class="bigDiv">
<div class="div1 com"></div>
<div class="div2 com"></div>
<div class="div3 com"></div>
</div>
<script>
// 函数封装区: 这别函数是封装好,后期不需要动的
// forwordTime函数是求到那一天哪一点的时间戳
function forwordTime(year, month, day, hour, minutes, seconds) {
var timeC = new Date(year, month - 1, day, hour, minutes, seconds);
var b = timeC.getTime();
return b;
}
// nowTime函数是求当前时间戳
function nowTime() {
var time = new Date();
var a = time.getTime();
// var second = parseInt(a / 1000) % 60;
return a;
}
// lastTime函数是求出二者的时间戳之差,之后变为字符串输出,例如10.10.10就是还剩下10小时,10分,10秒
function lastTime() {
// 获取forwordTime函数返还的时间戳
var a = timeValue;
// 获取nowTime函数返还的时间戳
var b = nowTime();
// 声明c来接受二者的时间戳差
var c = a - b;
// 把时间戳差转变为date对象,这里开始就有问题,返回之后多了一个月
// var g = d.getMonth();
var d = new Date(c);
// 用f来计算二者之间差的天数
var f = parseInt(c / (1000 * 24 * 60 * 60));
// 计算剩下的小时
var hour = d.getHours() + f * 24;
// 计算剩下的分钟
var month = d.getMonth();
//计算剩下的秒数
var second = d.getSeconds();
// 判断时分秒的长度是否为1,否则补0
if (hour.toString().length == 1) {
hour = 0 + "" + hour;
// console.log(hour);
}
if (month.toString().length == 1) {
month = 0 + "" + month;
// console.log(month);
}
if (second.toString().length == 1) {
second = 0 + "" + second;
// console.log(second);
}
// 用.拼接时分秒
var last = hour + "." + month + "." + second;
// console.log(f);
return last;
}
// endTime函数是将上方从lastTime函数获取的字符串根据.拆分,最后输入到三个div框中
function endTime() {
// console.log(lastTime());
var a = lastTime();
var arr = a.split(".");
// console.log(arr);
document.getElementsByClassName("div1")[0].innerHTML = arr[0] + "h";
document.getElementsByClassName("div2")[0].innerHTML = arr[1] + "m";
document.getElementsByClassName("div3")[0].innerHTML = arr[2] + "s";
}
// 时间修改区:只在这里修改时间即可,其他函数封装完毕,不用改动,输入的时间一定要大于当前时间,不然会有bug
var year = 2021;
var month = 8;
var day = 1;
var hour = 0;
var minutes = 0;
var seconds = 0;
var timeValue = forwordTime(year, month, day, hour, minutes, seconds);
// 运行结果区
setInterval(endTime, 1000);
// smile函数是将获取的时间打印到第一个div框中,以免改动
function smile() {
var a = "距离" + year + "年" + month + "月" + day + " " + hour + ":" + minutes + ":" + seconds + "还剩下!!!";
document.getElementsByTagName("div")[0].innerHTML = a;
}
smile();
</script>
</body>
</html>