1. 程式人生 > 程式設計 >JS實現網頁煙花動畫效果

JS實現網頁煙花動畫效果

原生js實現放煙花效果,點選滑鼠,然後向四周擴散,最後自由落體效果!最簡單的方法實現!

效果圖:

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>

更多JavaScript精彩特效分享給大家:

Javascript選單特效大全

javascript仿QQ特效彙總

JavaScript時鐘特效彙總

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。