话不多说代码给上,感觉不错还请一键三联!
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<link rel="icon" type="image/x-icon" href="" />
<title>code</title>
<style>
* {
margin: 0;
padding: 0;
}
body {
background-color: #000;
overflow: hidden;
min-width: 1600px;
min-height: 900px;
}
.box {
transform: rotate3d(0, 0, 0, 0deg);
transform-origin: 926px 576px;
transition: transform 5s;
transform-style: preserve-3d;
}
.stars {
position: absolute;
top: 50%;
left: 50%;
width: 3px;
height: 3px;
border-radius: 50%;
animation: opacity 3s linear infinite;
}
@keyframes opacity {
0% {
opacity: .9;
}
50% {
opacity: .5;
}
100% {
opacity: .99;
}
}
@keyframes animationColor {
0% {
background-position: 0 0;
}
100% {
background-position: -100% 0;
}
}
span {
position: absolute;
left: 100px;
top: 100px;
font-size: 32px;
font-weight: bolder;
font-family: cursive;
color: #ccc;
transition-property: left, top, transform, opacity;
transition-timing-function: ease;
-moz-transition-timing-function: ease;
-webkit-transition-timing-function: ease;
-o-transition-timing-function: ease;
transition-duration: 100ms;
}
@keyframes show_temp_me {
from {
opacity: 0;
}
to {
opacity: 1;
}
}
.heart {
opacity: 0;
position: absolute;
left: 1340px;
top: 546px;
font-size: 100px;
color: #f00;
text-shadow: 2px 2px 2px #f00;
z-index: 999;
transition: opacity 5s;
}
.heartBroken {
filter: blur(0.007em);
}
.heartBroken::before,
.heartBroken::after {
content: "❤";
position: absolute;
top: 0;
left: 0;
transform-origin: 50% 80%;
}
.heartBroken::before {
animation: crack1 2.5s linear 1s forwards;
clip-path: inset(0 50% 0 0);
}
.heartBroken::after {
animation: crack2 1.5s linear 200ms forwards;
clip-path: inset(0 0 0 50%);
}
@keyframes crack1 {
0% {
transform: rotateZ(0deg);
}
100% {
transform: rotateZ(-10deg);
}
}
@keyframes crack2 {
0% {
transform: rotateZ(0deg);
}
100% {
transform: rotateZ(10deg);
}
}
@keyframes beat {
0% {
transform: scale(1);
}
50% {
transform: scale(1.2)
}
100% {
transform: scale(1)
}
}
.box > div {
position: relative;
transition-property: left, top, opacity;
transition-duration: 3s;
transition-timing-function: ease-out;
}
span {
position: absolute;
left: 100px;
top: 100px;
font-size: 22px;
font-weight: bolder;
font-family: cursive;
color: #ccc;
transition-property: left, top, transform, opacity;
transition-timing-function: ease;
-moz-transition-timing-function: ease;
-webkit-transition-timing-function: ease;
-o-transition-timing-function: ease;
transition-duration: 100ms;
}
.broken {
transform: rotateZ(0deg);
transition-property: transform;
transition-timing-function: ease;
-moz-transition-timing-function: ease;
-webkit-transition-timing-function: ease;
-o-transition-timing-function: ease;
transition-duration: 1s;
}
#love_left {
transform-origin: 870px 780px;
}
#love_right {
transform-origin: 870px 730px;
}
.text_ta {
opacity: 0;
position: relative;
-webkit-background-clip: text;
color: transparent;
font-size: 100px;
transition-property: top, left, opacity;
transition-timing-function: ease;
-moz-transition-timing-function: ease;
-webkit-transition-timing-function: ease;
-o-transition-timing-function: ease;
transition-duration: 2s;
}
.arrow {
width: 222px;
height: 110px;
position: absolute;
top: -300px;
left: 770px;
transform: rotateZ(0deg);
transition-property: top, left, transform;
transition-duration: 1s;
}
.bloods {
position: absolute;
left: 34px;
top: 96px;
width: 32px;
height: 32px;
border-radius: 8px 42px 24px 42px;
background-color: #d30;
transform: rotate(45deg);
transition: top 3s;
}
</style>
</head>
<body>
<div class="stars" id="stars"></div>
<script>
let arr = ['one', 'two', 'three', 'four', 'five', 'six', 'seven']
let love_2 = {
one: [[], []],
two: [[], []],
three: [[], []],
four: [[], []],
five: [[], []],
six: [[], []],
seven: [[], []],
}
let love = {
one: [
[482, 482, 463, 463, 446, 446, 434, 434, 425, 425, 423, 423, 426, 426, 434, 434, 446, 446, 461, 461, 479, 479, 499, 499, 521, 521, 542, 542, 562, 562, 583, 583, 603, 603, 623, 623, 639, 639, 655, 655, 671, 671, 685, 685, 701, 701, 714, 714, 728, 728, 744, 744, 758, 758, 773, 773, 785],
[1366, 1388, 1353, 1401, 1337, 1417, 1318, 1436, 1296, 1458, 1274, 1482, 1252, 1504, 1231, 1526, 1213, 1544, 1198, 1559, 1187, 1568, 1180, 1575, 1177, 1578, 1178, 1577, 1180, 1575, 1184, 1571, 1192, 1563, 1202, 1553, 1215, 1540, 1230, 1525, 1246, 1509, 1262, 1493, 1279, 1476, 1295, 1460, 1312, 1443, 1328, 1427, 1345, 1410, 1361, 1394, 1378]
],
two: [
[501, 501, 489, 489, 471, 471, 456, 456, 445, 445, 444, 444, 447, 447, 455, 455, 468, 468, 486, 486, 507, 507, 527, 527, 546, 546, 566, 566, 586, 586, 605, 605, 622, 622, 638, 638, 653, 653, 667, 667, 681, 681, 694, 694, 708, 708, 724, 724, 737, 737, 752, 752],
[1366, 1388, 1346, 1408, 1333, 1421, 1317, 1437, 1299, 1455, 1278, 1476, 1257, 1497, 1237, 1517, 1221, 1533, 1208, 1546, 1201, 1553, 1200, 1554, 1200, 1554, 1202, 1552, 1206, 1548, 1215, 1539, 1228, 1526, 1242, 1512, 1258, 1496, 1272, 1482, 1287, 1467, 1304, 1450, 1320, 1434, 1335, 1419, 1352, 1402, 1367, 1388]
],
three: [
[520, 520, 510, 510, 498, 498, 481, 481, 465, 465, 464, 464, 467, 467, 480, 480, 497, 497, 518, 518, 538, 538, 557, 557, 578, 578, 598, 598, 614, 614, 631, 631, 645, 645, 660, 660, 673, 673, 688, 688, 703, 703, 716, 716, 733],
[1366, 1388, 1346, 1408, 1327, 1427, 1314, 1440, 1299, 1455, 1277, 1477, 1256, 1498, 1239, 1515, 1226, 1528, 1219, 1535, 1220, 1534, 1221, 1533, 1226, 1528, 1235, 1522, 1249, 1508, 1262, 1495, 1278, 1479, 1294, 1463, 1311, 1446, 1326, 1431, 1341, 1416, 1358, 1399, 1378]
],
four: [
[539, 539, 530, 530, 518, 518, 507, 507, 490, 490, 485, 485, 496, 496, 514, 514, 534, 534, 554, 554, 574, 574, 593, 593, 610, 610, 625, 625, 639, 639, 652, 652, 668, 668, 683, 683, 696, 696, 714],
[1366, 1388, 1346, 1408, 1327, 1427, 1307, 1447, 1294, 1460, 1272, 1482, 1254, 1500, 1241, 1513, 1241, 1513, 1242, 1512, 1247, 1507, 1259, 1495, 1271, 1483, 1286, 1468, 1303, 1451, 1321, 1433, 1335, 1419, 1350, 1404, 1366, 1388, 1379]
],
five: [
[559, 559, 550, 550, 539, 539, 530, 530, 514, 514, 516, 516, 538, 538, 558, 558, 578, 578, 597, 597, 613, 613, 627, 627, 639, 639, 655, 655, 672, 672],
[1366, 1388, 1344, 1410, 1324, 1430, 1304, 1450, 1286, 1468, 1265, 1489, 1262, 1493, 1263, 1492, 1275, 1480, 1287, 1468, 1304, 1451, 1321, 1434, 1339, 1416, 1352, 1400, 1366, 1387]
],
six: [
[580, 580, 570, 570, 560, 560, 550, 550, 536, 536, 556, 556, 576, 576, 592, 592, 606, 606, 619, 619, 634, 634, 650],
[1366, 1388, 1345, 1409, 1325, 1429, 1305, 1449, 1284, 1470, 1285, 1469, 1296, 1458, 1312, 1442, 1328, 1426, 1346, 1408, 1361, 1393, 1377]
],
seven: [
[603, 603, 592, 592, 578, 578, 621],
[1367, 1389, 1346, 1408, 1324, 1428, 1376]
]
}
function stars() {
let boxShadow = "";
for (let i = 0; i < 2000; i++) {
boxShadow += parseInt(1000 - (Math.random() * 2000)) + "px " + parseInt(1000 - (Math.random() * 2000)) + "px #" + Math.random().toString(16).substr(-6) + ",";
}
boxShadow = boxShadow.replace(/,$/gi, "");
document.getElementById("stars").style.boxShadow = boxShadow;
setTimeout(function () {
stars()
}, 6000)
}
window.onload = function () {
stars()
for (const value of arr) {
for (let i = 0; i < love[value][0].length; i++) {
love_2[value][0][i] = love[value][0][i] - 360
love_2[value][1][i] = love[value][1][i] - 1166
}
}
document.getElementsByTagName('body')[0].innerHTML += '<div id="box" class="box"><div style="opacity:0" class="ta" id="ta"></div><div class="me" id="me"></div></div>'
let object = new Class()
object.start()
}
let arrow = {
top: [0, 16, 38, 62, 80, 38, 38, 38, 38, 38, 38, 38, 38, 38, 0, 14, 62, 80],
left: [0, 15, 31, 15, 0, 50, 69, 88, 107, 126, 145, 164, 183, 202, 171, 189, 189, 171],
rotate: [300, 300, 270, 225, 225, 270, 270, 270, 270, 270, 270, 270, 270, 270, 300, 300, 225, 225]
}
class Class {
async start() {
await this.showTA()
await this.show_me()
await this.discolor_me()
await this.show_ta_one()
await this.change_me_color()
await this.heart()
await this.show_ta_all()
await this.near()
await this.rotate()
await this.separate()
await this.arrow()
await this.heartBroken_()
await this.drippingBlood()
await this.ta_disappear()
await this.broken()
this.end()
}
showTA() {
let that = this
return new Promise(function (resolve) {
let width = document.documentElement.clientWidth
let height = document.documentElement.clientHeight
let backgroundImage = ""
for (let i = 0; i < 10; i++) {
backgroundImage += "#" + Math.random().toString(16).substr(-6) + ","
}
backgroundImage = backgroundImage.replace(/,$/gi, ');"');
let style = '"text-fill-color:transparent;background-clip:text;background-size:200% 100%;left:' + (width / 2 - 50) + 'px;top:' + (height / 2 - 50) + 'px;background-image: linear-gradient(to right,' + backgroundImage
document.getElementsByTagName('body')[0].innerHTML += '<p id="text_ta" class="text_ta" style=' + style + '>我喜欢你,(名字)</p>'
let element = document.getElementById('text_ta')
setTimeout(function () {
element.style.opacity = '1'
},500)
setTimeout(function () {
element.style.top = "180px"
element.style.left = "165px"
element.style.animation = "animationColor 5s infinite linear"
setTimeout(function () {
resolve("showTA")
}, 2500)
}, 2800)
that.text_ta_backgroundImage_interval = setInterval(function () {
let backgroundImage = ""
for (let i = 0; i < 10; i++) {
backgroundImage += "#" + Math.random().toString(16).substr(-6) + ","
}
backgroundImage = backgroundImage.replace(/,$/gi, ')');
element.style.backgroundImage = 'linear-gradient(to right,' + backgroundImage
}, 3000)
})
}
show_me() {
return new Promise(async function (resolve, reject) {
document.getElementById("me").innerHTML += '<div id="love_left" class="broken"></div>'
document.getElementById("me").innerHTML += '<div id="love_right" class="broken"></div>'
let love_left = document.getElementById('love_left')
let love_right = document.getElementById('love_right')
let color = "#858585"
for (const value of arr) {
for (let i = 0; i < love[value][0].length; i++) {
if (i % 2 === 0) {
love_left.innerHTML += "<span id=" + value + "_" + i + " style='opacity:0;color:" + color + ";top:" + love[value][0][i] + "px;left:" + love[value][1][i] + "px;text-shadow:2px 2px 2px " + color + ";'>❤</span>"
} else {
love_right.innerHTML += "<span id=" + value + "_" + i + " style='opacity:0;color:" + color + ";top:" + love[value][0][i] + "px;left:" + love[value][1][i] + "px;text-shadow:2px 2px 2px " + color + ";'>❤</span>"
}
}
}
for (const value of arr) {
for (let i = 0; i < love[value][0].length; i++) {
await new Promise(function (resolve) {
setTimeout(function () {
let element = document.getElementById(value + "_" + i)
element.style.opacity = "1"
resolve()
}, 20)
})
}
}
resolve("show_me")
})
}
discolor_me() {
let interval = '';
let time = 800;
return new Promise(function (resolve) {
interval = setInterval(discolor, time)
function discolor() {
let element = "";
for (const value of arr) {
for (let i = 0; i < love[value][0].length; i++) {
element = document.getElementById(value + "_" + i)
element.style.color = "#" + Math.random().toString(16).substr(-6)
element.style.textShadow = "2px 2px 2px #" + Math.random().toString(16).substr(-6)
}
}
clearInterval(interval);
if (time > 400) {
time -= 80;
} else if (time > 390) {
time -= 1;
resolve("discolor_me")
}
if (time > 390) {
interval = setInterval(discolor, time);
}
}
})
}
show_ta_one() {
let that = this
return new Promise(function (resolve) {
let i = 0;
let text_ta = document.getElementById('text_ta')
text_ta.style.transitionDuration = "4s"
text_ta.style.opacity = "0"
clearInterval(that.text_ta_backgroundImage_interval)
setTimeout(function () {
document.getElementById("text_ta").remove()
}, 5000)
document.getElementById("box").innerHTML += '<div id="temp_ta" class="temp_ta"></div>'
let element = document.getElementById('temp_ta')
let interval = setInterval(function () {
element.innerHTML += "<span id=temp_" + i + " style='z-index:-1;opacity:1;:#858585;top:" + love_2.one[0][i] + "px;left:" + love_2.one[1][i] + "px;text-shadow:2px 2px 2px #858585;'>❤</span>"
i++
if (i === love_2.one[0].length) {
clearInterval(interval)
setTimeout(function () {
resolve("show_ta_one")
}, 500)
}
}, 50)
})
}
change_me_color() {
let that = this
return new Promise(async function (resolve) {
document.getElementById("me").innerHTML += '<div style="opacity:0;" id="temp_me" class="temp_me"></div>'
let element = document.getElementById("temp_me")
for (const value of arr) {
for (let i = 0; i < love[value][0].length; i++) {
element.innerHTML += "<span id=temp_" + value + "_" + i + " style='color:#EB098E;top:" + love[value][0][i] + "px;left:" + love[value][1][i] + "px;text-shadow:2px 2px 2px #FDB0DA;'>❤</span>"
}
}
setTimeout(function () {
element.style.animation = "show_temp_me 5s"
setTimeout(function () {
for (const value of arr) {
for (let i = 0; i < love[value][0].length; i++) {
let element = document.getElementById(value + "_" + i)
element.style.color = "#EB098E"
element.style.textShadow = "2px 2px 2px #FDB0DA"
}
}
setTimeout(function () {
document.getElementById("temp_me").remove()
}, 6000)
}, 4000)
resolve("change_me_color")
}, 500)
})
}
heart() {
return new Promise(function (resolve) {
document.getElementById('me').innerHTML += '<p data-text="❤" id="heart" class="heart">❤</p>'
let heart = document.getElementById("heart")
setTimeout(function () {
heart.style.opacity = "1"
heart.style.zIndex = "3"
}, 20)
setTimeout(function () {
heart.style.animation = "beat 1s linear infinite"
setTimeout(function () {
resolve("heart")
}, 500)
}, 4500)
})
}
show_ta_all() {
return new Promise(function (resolve) {
let element = document.getElementById("ta")
for (const value of arr) {
for (let i = 0; i < love_2[value][0].length; i++) {
element.innerHTML += "<span id=" + value + "_" + i + " style='color:#FDB0DA;top:" + love_2[value][0][i] + "px;left:" + love_2[value][1][i] + "px;text-shadow:2px 2px 2px #EB098E;'>❤</span>"
}
}
setTimeout(function () {
element.style.opacity = "1"
setTimeout(function () {
document.getElementById("temp_ta").remove()
resolve("show_ta_all")
}, 3500)
}, 500)
})
}
near() {
return new Promise(function (resolve) {
let me = document.getElementById("me");
let ta = document.getElementById("ta");
me.style.top = "0";
me.style.left = "0";
ta.style.top = "0";
ta.style.left = "0";
setTimeout(function () {
me.style.top = "-132px";
me.style.left = "-364px";
ta.style.top = "230px";
ta.style.left = "600px";
setTimeout(function () {
resolve("near");
}, 4000)
}, 100)
})
}
rotate() {
return new Promise(function (resolve) {
document.getElementById("box").style.transform = "rotate3d(1,1,1,360deg)";
setTimeout(function () {
resolve("rotate")
}, 6500)
})
}
separate() {
return new Promise(function (resolve) {
let ta = document.getElementById("ta")
ta.style.top = "0"
ta.style.left = "0"
setTimeout(function () {
resolve()
}, 3500)
})
}
arrow() {
return new Promise(function (resolve) {
let me = document.getElementById("me")
me.innerHTML += '<div class="arrow" id="arrow"></div>'
let element = document.getElementById("arrow");
for (let i = 0; i < 18; i++) {
let style = "'z-index:2;color:#fe0;top:" + arrow.top[i] + "px;left:" + arrow.left[i] + "px;transform: rotate(" + arrow.rotate[i] + "deg)'"
element.innerHTML += '<span id="arrow_' + i + '" style=' + style + '>❤</span>'
}
setTimeout(function () {
element.style.top = parseInt(Math.random() * (400 - 100) + 100) + "px";
}, 1000)
setTimeout(function () {
let heart = document.getElementById("heart")
let heart_center_x = Math.floor(heart.getBoundingClientRect().left) + Math.floor(heart.getBoundingClientRect().width / 2)
let heart_center_y = Math.floor(heart.getBoundingClientRect().top) + Math.floor(heart.getBoundingClientRect().height / 2)
let arrow = document.getElementById("arrow")
let rotate = 360 * Math.atan((arrow.getBoundingClientRect().y - heart.getBoundingClientRect().y) / (arrow.getBoundingClientRect().x - heart.getBoundingClientRect().x)) / (2 * Math.PI);
element.style.transform = "rotate(" + rotate + "deg)"
let x = heart_center_x + Math.abs(me.getBoundingClientRect().left) - (arrow.getBoundingClientRect().width / 2)
let y = heart_center_y + Math.abs(me.getBoundingClientRect().top) - (arrow.getBoundingClientRect().height / 2)
setTimeout(function () {
element.style.top = y + 'px'
element.style.left = x + 'px'
setTimeout(function () {
heart.style.animation = ""
resolve()
}, 2000)
}, 2000)
}, 3000)
})
}
heartBroken_() {
return new Promise(function (resolve) {
let element = document.getElementById('heart')
element.classList.add("heartBroken")
setTimeout(function () {
element.innerHTML = ''
element.innerText = ''
setTimeout(function () {
document.getElementById('arrow').style.top = window.screen.height + 200 + "px"
setTimeout(function () {
resolve()
}, 2000)
}, 2000)
}, 800)
})
}
drippingBlood() {
return new Promise(function (resolve) {
let height = document.documentElement.clientHeight + 50
let heart = document.getElementById("heart")
heart.innerHTML += '<div id="blood"></div>'
let blood = document.getElementById('blood')
let i = 1;
let stop = 10;
let intervalID = setInterval(function () {
if (i === 6){
resolve()
}
if (i > stop) {
clearInterval(intervalID)
return
}
blood.innerHTML += "<p id='blood_" + i + "'class='bloods'></p>"
start(i)
i++
}, 1000)
function start(i){
if(i === stop){
setTimeout(function () {
blood.innerHTML = ''
},2100)
}
setTimeout(function () {
document.getElementById("blood_" + i).style.top = height+"px"
}, 50)
}
})
}
ta_disappear(){
return new Promise(function (resolve){
let ta = document.getElementById('ta');
ta.style.top = "-300px"
ta.style.left = "-200px"
ta.style.opacity = '0'
setTimeout(function () {
document.getElementById("heart").style.opacity = '0'
setTimeout(function () {
resolve()
},3500)
},3000)
})
}
broken(){
return new Promise(function (resolve){
let height = window.screen.height * 1.2
let width = window.screen.width * 1.2
let top = "";
let left = "";
let love_left = document.getElementById('love_left').childNodes;
let love_right = document.getElementById('love_right').childNodes
for (let i = 0; i < love_left.length; i++) {
top = parseInt(Math.random() * (height - 1) + 1)
left = parseInt(Math.random() * (width - 1) + 1)
love_left[i].style.transitionDuration = '3s';
love_left[i].style.top = top + "px";
love_left[i].style.left = left + "px";
love_left[i].style.transform = "rotate("+(Math.random() * (360 - 1) + 1)+"deg)"
}
for (let i = 0; i < love_right.length; i++) {
top = parseInt(Math.random() * (height - 1) + 1)
left = parseInt(Math.random() * (width - 1) + 1)
love_right[i].style.transitionDuration = '3s';
love_right[i].style.top = top + "px";
love_right[i].style.left = left + "px";
love_right[i].style.transform = "rotate("+(Math.random() * (360 - 1) + 1)+"deg)"
}
setTimeout(function () {
resolve()
},3500)
})
}
end(){
document.getElementById('me').style.opacity = '0'
setTimeout(function () {
let body = document.getElementsByTagName('body');
body.removeChild(document.getElementById('box'));
},5000)
}
}
</script>
</body>
</html>