【原生小人趣味表白(2020雙十一前一天的囂張嗚嗚嗚......)----使用js等實現】
先來看一下實現的效果哈!
說明
(1)大家也許很可能在某手,某音等平臺上邊看到過這個哈哈!不過因為涉及到一些素材(圖片),發出來比較囉嗦,因此上傳到了本部落格的“下載”裡邊,素材全部都有,大家儘可以隨意下載。
(2)原始碼將全部上傳,下面是所有的原始碼。
原始碼
(1) love.css
* {
margin: 0;
padding: 0;
border: 0;
}
.icon-love {
width: 400px;
}
html, body {
width: 100%;
height: 100%;
}
body {
/*background-color: skyblue;*/
overflow: hidden; /*隱藏超出的部分*/
}
.container {
width: 100%;
height: 100%;
position: relative;
}
/*---------------------- body_left -------------------------*/
.body_left {
width: 300px;
height: 300px;
left: 0;
bottom: 110px;
position: absolute;
z-index: 98;
}
/*---------------------- body_left -------------------------*/
/*---------------------- body_center -------------------------*/
.container .love {
width: 520px; /* 13 * 40 */
height: 440px; /* 11 * 40 */
left: 50%;
top: 50%;
position: absolute;
margin: -260px 0 0 -220px;
/*background-color: gray;*/
}
.love .block {
right: 0;
position: absolute;
visibility: hidden; /*未開始升空動畫前隱藏*/
background-color: yellow;
}
.love .block div {
width: 40px;
height: 40px;
position: absolute;
background: url("../images/heart.png") no-repeat;
background-size: contain;
/*background-color: #c40908;*/
/*border: 1px solid silver;*/
box-sizing: border-box;
}
/*---------------------- body_center -------------------------*/
/*---------------------- footer -------------------------*/
@keyframes border {
0% {
width: 0;
}
5% {
width: 5%;
}
10% {
width: 10%;
}
15% {
width: 15%;
}
20% {
width: 20%;
}
25% {
width: 25%;
}
30% {
width: 30%;
}
35% {
width: 35%;
}
40% {
width: 40%;
}
45% {
width: 45%;
}
50% {
width: 50%;
}
55% {
width: 55%;
}
60% {
width: 60%;
}
65% {
width: 65%;
}
70% {
width: 70%;
}
75% {
width: 75%;
}
80% {
width: 80%;
}
85% {
width: 85%;
}
90% {
width: 90%;
}
95% {
width: 95%;
}
100% {
width: 100%;
}
}
.footer {
bottom: 30px;
position: relative;
z-index: 99;
}
.footer .border .border-top {
/*width: 0;*/
/*display: inline-block;*/
border-top: 3px solid black;
transform-origin: left center;
-webkit-animation: border 312 linear;
-o-animation: border 12s linear;
animation: border 12s linear;
animation-fill-mode : both;
/*border-bottom: none;*/
}
.footer .border .border-bottom {
/*width: 0;*/
/*display: inline-block;*/
float: right;
border-top: 3px solid red;
transform-origin: right center;
-webkit-animation: border 7s linear 12s;
-o-animation: border 7s linear 12s;
animation: border 7s linear 12s;
animation-fill-mode : both;
/*border-bottom: none;*/
}
.footer .copyright {
width: 100%;
height: 30px;
position: absolute;
bottom: -30px;
text-align: center;
/*background-color: gray;*/
}
.copyright div {
width: 30%;
line-height: 30px;
display: inline-block;
}
.copyright div span {
color: dimgray;
}
/*---------------------- footer -------------------------*/
(2)love.js
const blk_pitn = { //各小方塊相對【自身中心】的位置 -- 【自身中心】確定為#div22的方塊
block1: [[0, 1], [0, 0], [-1, 0], [-1, -1]],
block2: [[0, 1], [0, 0], [-1, 0], [0, -1]],
block3: [[-1, 1], [0, 0], [-1, 0], [-1, -1]],
block4: [[0, 1], [0, 0], [-1, 0], [-1, -1]], /* 1 */
block5: [[-1, 1], [0, 0], [-1, 0], [0, -1]],
block6: [[0, -1], [0, 0], [-1, 0], [1, -1]],
block7: [[-1, -1], [0, 0], [-1, 0], [1, 0]],
block8: [[-1, 1], [0, 0], [-1, 0], [-1, -1]], /* 3 */
block9: [[0, -1], [0, 0], [-1, 0], [1, 0]],
block10: [[-1, 1], [0, 0], [-1, 0], [1, 0]],
block11: [[2, 0], [0, 0], [-1, 0], [1, 0]], /* — */
block12: [[0, 1], [0, 0], [-1, 0], [0, -1]], /* 2 */
block13: [[0, 1], [0, 0], [-1, 0], [-1, -1]], /* 1 */
block14: [[1, 1], [0, 0], [-1, 0], [1, 0]],
block15: [[1, -1], [0, 0], [-1, 0], [1, 0]],
block16: [[-1, -1], [0, 0], [-1, 0], [1, 0]], /* 7 */
block17: [[0, 1], [0, 0], [-1, 0], [0, -1]], /* 2 */
block18: [[0, 1], [0, 0], [-1, 0], [-1, -1]], /* 1 */
block19: [[0, -1], [0, 0], [-1, 0], [1, 0]], /* 9 */
block20: [[1, -1], [0, 0], [-1, 0], [1, 0]],
block21: [[0, 1], [0, 0], [-1, 0], [-1, -1]], /* 1 */
block22: [[1, 1], [0, 0], [-1, 0], [1, 0]], /* 14 */
block23: [[0, 2], [0, 0], [0, -1], [0, 1]] /* | */
},
offset_pitn = { //各方塊block相對【愛心中心】的位置
block1: [5, 3],
block2: [5, 1],
block3: [3, 4],
block4: [3, 2],
block5: [3, -1],
block6: [2, 5],
block7: [2, 1],
block8: [1, -1],
block9: [1, -3],
block10: [1, 2],
block11: [0, 3],
block12: [0, 0], /* 【愛心中心】*/
block13: [-1, -4],
block14: [0, -2],
block15: [-2, 4],
block16: [-2, 2],
block17: [-2, 0],
block18: [-3, -2],
block19: [-4, 0],
block20: [-3, 5],
block21: [-5, 3],
block22: [-4, 1],
block23: [-6, 1] /* 因動畫需要移動一個方塊,故y軸座標-1*/
};
let blocks = document.getElementsByClassName("block"),
block = blocks[0],
love = document.getElementsByClassName("love")[0],
timer = null,
index = 0, //記錄拼接愛心的動畫步驟
clone_block; //用於克隆方塊
//1.移動方塊的【自身中心】到【愛心中心】
block.style.top = "50%";
block.style.left = "50%";
block.style.margin = "-20px 0 0 -20px";
const block_left = parseFloat(window.getComputedStyle(block, null).left.slice(0, -2)), //【愛心中心】 左邊距離父元素的距離
block_top = parseFloat(window.getComputedStyle(block, null).top.slice(0, -2)); //【愛心中心】 頂部距離父元素的距離
function Next() {
if (++index >= 24) {
clearInterval(timer);
Rise();
// alert("已經是最後一個了!");
return;
}
block.style.visibility = "visible"; //升空動畫前允許可見
//2.移動方塊到指定的位置-即是移動【自身中心】到目標位置
block.style.left = block_left + 40 * offset_pitn["block" + index][0] + "px";
block.style.top = block_top - 40 * offset_pitn["block" + index][1] + "px";
for (let i = 0; i < block.children.length; i++) {
// block.children[1].innerText = index; //編號便於除錯
block.children[i].style.left = blk_pitn["block" + index][i][0] * -40 + "px";
/* -40 是因為邏輯座標和瀏覽器的x,y軸方向不一樣*/
block.children[i].style.top = blk_pitn["block" + index][i][1] * -40 + "px";
}
//3.克隆方塊—儲存現在的位置
/* 一共會克隆23個方塊,加上原先的一個方塊block,共24個方塊,即多出原先的block方塊*/
clone_block = block.cloneNode(true);
love.appendChild(clone_block);
if (love.children.length >= 24) {
blocks[blocks.length - 1].children[2].style.display = "none"; //去掉多餘的小方塊
block.style.display = "none"; //隱藏多出的block方塊
}
}
function Rise() {
//4.愛心升高,多出的那個小方塊開始掉落
console.log("開始升空");
let timer2 = null,
distance = 0;
/* 升高時,移動的距離*/
const target = 120, /* 目標距離*/
speed = 1;
/*移動速度*/
let love_top = parseFloat(window.getComputedStyle(love, null).top.slice(0, -2)); //愛心盒子距離螢幕頂部的距離
timer2 = setInterval(() => {
distance += speed;
// console.log(distance);
if (distance >= target) {
clearInterval(timer2);
console.log("升空完畢");
}
love.style.top = (love_top - distance) + "px";
}, 22);
}
window.onload = function () {
setTimeout(() => {
timer = setInterval(() => {
Next();
}, 300);
}, 12000); //gif圖播放完畢所需時間為11.73s
};
(3) 表白.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>心心--表白!</title>
<link href="favicon.ico" rel="shortcut icon" class="icon-love" type="images/x-ico">
<link rel="stylesheet" href="css/love.css">
</head>
<body>
<div class="container" onselectstart="return false;" unselectable="on" style="-moz-user-select:none;">
<div class="body_left">
<img src="images/biubiubiu.gif" alt="" ondragstart='return false;'>
</div>
<div class="body_center love">
<div class="block">
<div class="div1"></div>
<div class="div2"></div>
<div class="div3"></div>
<div class="div4"></div>
</div>
</div>
</div>
<div class="footer">
<div class="border">
<div class="border-top"></div>
<div class="border-bottom"></div>
</div>
<div class="copyright">
<div id="version"><span>Version:</span> 0.0.1</div>
<div id="createTime"><span>Time:</span> 2020/11/10</div>
<div id="author"><span>© </span>小啊瘋</div>
</div>
</div>
<script type="text/javascript" src="js/love.js"></script>
</body>
</html>
相關文章
- 嗚嗚
- 牛客周賽 Round 40 (小白醬的被虐之旅嗚嗚嗚)
- 嗚嗚,這個網站的標籤系統好亂呀網站
- 阿里,位元組都不要我!臥薪嚐膽33天,才艱難六面拿到美團offer,這也太難了吧,嗚嗚嗚~阿里
- 通過原生js實現資料的雙向繫結JS
- HTML+CSS+JS實現趣味相簿HTMLCSSJS
- 如何使用Android原生介面,實現“應用雙開”Android
- 用原生 JS 實現雙向繫結及應用例項JS
- 科尼爾:雙十一喧囂之後的冷靜思考及覆盤(附下載)
- 原生js實現replace方法JS
- 原生js實現拖拽功能JS
- JS的雙等和三等的區別JS
- 原生JS實現輪播圖的效果JS
- 用原生 JS 實現 innerHTML 功能JSHTML
- JS原生實現觀察者模式JS模式
- 原生js實現輪播圖JS
- 原生JS實現影片截圖JS
- 原生JavaScript實現AJAX、JSONPJavaScriptJSON
- ChatGPT4實現前一天ChatGPT
- 使用原生js實現選項卡功能例項教程JS
- 如何使用原生 JS 實現一個文字劃線功能JS
- 使用原生javascript實現jquery的$(function(){ })JavaScriptjQueryFunction
- 原生js實現商品排序功能JS排序
- 用原生js手寫實現promiseJSPromise
- 原生JS實現二級聯動JS
- 原生JS實現頁面內定位JS
- 原生js實現發簡訊~chatJS
- 2020阿里雲雙十一,騰訊雲雙十一雲伺服器有優惠嗎?阿里伺服器
- 原生js雙向資料繫結JS
- 原生js實現物件的深克隆以及淺克隆JS物件
- 原生js實現購物車結算JS
- 原生 js 實現一個前端路由 routerJS前端路由
- JS原生實現表單序列化JS
- 原生JS實現貼上到剪貼簿JS
- 原生 JS 實現 HTML 轉 Markdown,以及其實現邏輯JSHTML
- 工商總局局長張茅到訪阿里預祝“雙十一”成功阿里
- 第三十一天 js實現的複雜驗重 (不推薦使用)JS
- js 實現vue的雙向資料繫結JSVue