您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關JS如何實現網頁煙花動畫效果,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
效果圖:
CSS代碼:
*{ padding: 0px; margin: 0px; background: #000; } .firworks{ width: 6px; height: 6px; position: absolute; }
js代碼:
<script type="text/javascript"> //封裝一個顏色隨機的效果 function randomColor(){ var color = "rgb(" var r = parseInt(Math.random()*256); var g = parseInt(Math.random()*256); var b = parseInt(Math.random()*256); color = color+r+","+g+","+b+")"; return color; } //創建一個制造煙花的構造函數,第一個參數為元素,第二參數為初始x軸位置,第三參數為y軸位置。 function Fireworks(Div,x,y){ Div.style.backgroundColor=randomColor(); //給煙花添加背景色 Div.className="firworks"; //添加一個class document.body.appendChild(Div); Div.style.left=x+"px"; //把鼠標點擊坐標給div Div.style.top=y+"px"; var speedX = (parseInt(Math.random()*2) == 0 ? 1 : -1)*parseInt(Math.random()*16 + 1); //三目運算符隨機移動方向,概率50%,為1時往正方向移動,負1時往反方向移動第二個隨機數隨機速度快慢 var speedY = (parseInt(Math.random()*2) == 0 ? 1 : -1)*parseInt(Math.random()*20 + 1); this.move=function(){ var i = 3; var time1=setInterval(function(){ i++; Div.style.left=Div.offsetLeft+speedX+"px"; Div.style.top=Div.offsetTop+speedY+i+"px"; //當i+speedY>0時,煙花朝下運動。 if(Div.offsetLeft+Div.offsetWidth>window.innerWidth|| Div.offsetLeft<2 || Div.offsetTop+Div.offsetHeight>window.innerHeight || Div.offsetTop<2 ){ Div.remove(); //移動出可視區域記得刪除div和清除定時器 clearInterval(time1); } },30); } } document.οnclick=function (e){ var evt=e||window.event; //兼容性處理 for(var i=0;i<80;i++){ //隨機煙花的數量 var div=document.createElement("div"); var b=new Fireworks(div,evt.pageX,evt.pageY); b.move(); } } </script>
關于“JS如何實現網頁煙花動畫效果”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。