利用JavaScript實(shí)現(xiàn)放鞭炮動(dòng)畫效果
前言
談及過(guò)年,最先讓人想到的就是,噼里啪啦的鞭炮聲,小時(shí)候到了春節(jié),點(diǎn)上一根香,把紅色的鞭炮從那一排子里解出幾個(gè),放在石頭上,用香火點(diǎn)著捻子,只聽(tīng)“啪"的一聲,鞭炮響了,鞭炮皮炸了一地,爽的不行;然而現(xiàn)在由于各種原因不能像小時(shí)候一樣痛快的放鞭炮了,鞭炮就是過(guò)年的靈魂,過(guò)年要是不放點(diǎn)煙花爆竹,總感覺(jué)少了點(diǎn)年味,沒(méi)意思透了。只能在網(wǎng)上來(lái)實(shí)現(xiàn)這個(gè)小小的心愿了,體驗(yàn)小時(shí)候路邊放鞭炮的快樂(lè)時(shí)光。效果圖如下:
制作思路
1)首先構(gòu)建一串鞭炮
2)點(diǎn)炮,兔年這個(gè)任務(wù)就交給可愛(ài)的小兔吧
3)制作鞭炮爆炸效果
4)添加鞭炮音效
代碼實(shí)現(xiàn)
構(gòu)建鞭炮
首先準(zhǔn)備一條豎線,作為這串鞭炮的總捻子。
然后沿著捻子在兩邊排放鞭炮,每個(gè)鞭炮的實(shí)現(xiàn)方式如下:
<div class="bp-item bp-right bg-delay1 bg-ani-name1" style="left: 127px;top:59.77230769230769px;"> <div class="bp-wrap"> <div class="bp" style="transform: scale(0.8) rotate(-19deg);"> <div class="top"> <i></i> </div> <div class="side up"> <i></i> </div> <div class="side down1"> <i></i> </div> <div class="side down2"> <i></i> </div> <div class="bottom foot"> </div> <div class="text"> <div class="out"> <div class="mid"> <div class="in"> </div> </div> </div> <span>新</span> </div> </div> <div class="bang bang2"> </div> </div> </div>
安排小兔上場(chǎng)點(diǎn)火
兔年點(diǎn)炮動(dòng)作就交給小兔吧!在上面加個(gè)按鈕用來(lái)觸發(fā)點(diǎn)炮動(dòng)作。
$(".dear-joy").bind("click", function() { $(this).removeClass("jump").addClass("dian"); setTimeout(function() { f.trigger("bang") //觸發(fā)鞭炮爆炸效果 }, 500); $(".dear-joy2").addClass("fadeIn") }); //鞭炮爆炸 f.bind("bang", function() { var w = $(this).find(".bp-item"); w.each(function(y, z) { setTimeout(function() { $(z).addClass("on hold-forwards bp-fly") }, (w.length - y + 4) * 150) }); plays();//啟聲音 setTimeout(function() { _audioDom.pause() //音頻暫停 }, 6000); });
爆炸效果
.hold-forwards { -webkit-animation-fill-mode: forwards !important; animation-fill-mode: forwards !important; } .on .bp { -webkit-animation: easeOut .2s ease-in; animation: easeOut .2s ease-in; }
添加音頻
沒(méi)有聲音的鞭炮是沒(méi)有靈魂的。
<audio src="http://downsc.chinaz.net/Files/DownLoad/sound/huang/cd9/mp3/222.mp3" id="audio_box"></audio>
到此這篇關(guān)于利用JavaScript實(shí)現(xiàn)放鞭炮動(dòng)畫效果的文章就介紹到這了,更多相關(guān)JavaScript放鞭炮動(dòng)畫內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
bootstrap table合并行數(shù)據(jù)并居中對(duì)齊效果
這篇文章主要為大家詳細(xì)介紹了bootstrap table合并行數(shù)據(jù)并居中對(duì)齊效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-10-10JS獲取當(dāng)前網(wǎng)址、主機(jī)地址項(xiàng)目根路徑
本文為大家提供JS如何獲取當(dāng)前網(wǎng)址、主機(jī)地址之后的目錄及項(xiàng)目根路徑的方法,喜歡的朋友可以收藏下2013-11-11使用JS來(lái)動(dòng)態(tài)操作css的幾種方法
這篇文章主要介紹了使用JS來(lái)動(dòng)態(tài)操作css的幾種方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12JavaScript對(duì)JSON數(shù)組簡(jiǎn)單排序操作示例
這篇文章主要介紹了JavaScript對(duì)JSON數(shù)組簡(jiǎn)單排序操作,結(jié)合實(shí)例形式分析了javascript使用sort()方法針對(duì)json數(shù)組元素排序的相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下2019-01-01原生JS實(shí)現(xiàn)表單checkbook獲取已選擇的值
本文為大家介紹下采用原生JS實(shí)現(xiàn)從一個(gè)表單checkbox獲取到已選中的數(shù)據(jù)值,具體的實(shí)現(xiàn)如下,感興趣的朋友可以參考下哈,希望對(duì)大家有所幫助2013-07-07JavaScript 大數(shù)據(jù)相加的問(wèn)題
寫一個(gè)函數(shù)處理大數(shù)據(jù)的相加問(wèn)題,所謂的大數(shù)據(jù)是指超出了整型,長(zhǎng)整型之類的常規(guī)數(shù)據(jù)類型表示范圍的數(shù)據(jù)。實(shí)現(xiàn)語(yǔ)言不限。2011-08-08js實(shí)現(xiàn)1,2,3,5數(shù)字按照概率生成
這篇文章主要介紹了js實(shí)現(xiàn)1,2,3,5數(shù)字按照概率生成,需要的朋友可以參考下2017-09-09