首页 > 分享 > HTML超级浪漫的独一无二的爱心表白代码,亲测可用!

HTML超级浪漫的独一无二的爱心表白代码,亲测可用!

话不多说代码给上,感觉不错还请一键三联!

<!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>

相关知识

基于HTML实现浪漫情人节表白代码(附源代码)
【博主推荐】HTML浪漫表白求爱(附源码)
程序员的浪漫!用Python实现表白代码!
HTML浪漫表白求爱(附源码)
七夕最浪漫的表白,最真挚的感情(Python代码实现)
一大束玫瑰花HTML代码
用C WinForm打造浪漫惊喜:超级简单哄女朋友开心的小程序
HTML5七夕情人节表白网页制作【css求婚动画源码】HTML+CSS+JavaScript 程序员表白代码
520表白网页,程序员浪漫表白,求婚倒计时网站制作 HTML+CSS+JS
Python浪漫表白源码合集(爱心、玫瑰花、照片墙、星空下的告白)

网址: HTML超级浪漫的独一无二的爱心表白代码,亲测可用! https://m.huajiangbk.com/newsview792688.html

所属分类:花卉
上一篇: 一行代码教你七夕情人节如何告白❤
下一篇: html动态爱心代码【一】(附源