赞
踩
话不多说代码给上,感觉不错还请一键三联!
- <!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>
赞
踩
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。