亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

原生JS實現煙花效果

瀏覽:73日期:2024-05-19 14:38:34

原生JS實現煙花效果,點擊頁面生成煙花,向四周擴散,然后再墜落下去。(這里的煙花我是用的特殊字符愛心形狀)

原生JS實現煙花效果

基礎css代碼

/* 設置基礎的css樣式 */ body{background: #000;overflow: hidden;} .fire{position: absolute;width: 4px;height: 30px;}

js代碼:

1、給頁面添加點擊事件,生成主體煙花

//給頁面設置點擊事件 document.onclick = function(eve){ var e = eve || window.event; //設置一個空數組,用來后面存放小煙花 var arr = []; //獲取鼠標點擊的位置 var x = e.clientX; var y = e.clientY; //設置步長 var speed = 20; //生成大煙花,設置他的css樣式,出發點在可視區頁面的下方 var fire = document.createElement(’div’); fire.className = ’fire’; fire.style.background = randomColor(); fire.style.left = x + ’px’; fire.style.top = document.documentElement.clientHeight+’px’; //將大煙花追加到頁面上 document.body.appendChild(fire);

2、設置定時器,讓煙花向上運動,刪除

//生成定時器 var t = setInterval(function(){ //判斷如果大煙花的TOP值小于小于目標值,清除定時器,并且將大煙花清除 if(fire.offsetTop <= y){ clearInterval(t); document.body.removeChild(fire); //執行show(生成小煙花) show(); } //讓大煙花垂直向上運動 fire.style.top = fire.offsetTop - speed +’px’; },30);

3、然后在點擊的位置生成小煙花,設置樣式

function show(){ //利用循環,生成50個小煙花,給小煙花添加css屬性 for(var i=0;i<50;i++){ var sFire = document.createElement(’div’); // sFire.className = ’small-fire’; sFire.style.left = x +’px’; sFire.style.top = y +’px’; // sFire.style.background = randomColor(); sFire.style.color = randomColor(); sFire.innerHTML = ’❤’; sFire.style.position = ’absolute’; //生成隨機數 var a=Math.random()*360; sFire.sx = Math.sin(a*180/Math.PI)*20*Math.random(); sFire.sy = Math.cos(a*180/Math.PI)*20*Math.random(); //將小煙花追加到頁面上 document.body.appendChild(sFire); //將生成的煙花信息都添加到數組中 arr.push(sFire); } }

4、設置定時器,讓小煙花完成自由落體運動

setInterval(function move(){ //利用循環一直改變小煙花的位置 for(var i=0;i<arr.length;i++){ //設置將每次循環的第i個小煙花的運動范圍 arr[i].style.left = arr[i].offsetLeft + arr[i].sx + ’px’; arr[i].style.top = arr[i].offsetTop + arr[i].sy + ’px’; //讓煙花垂直方向的位置每次都增加,實現下落效果 arr[i].sy += 1; //判斷煙花是否運動出屏幕可視區,如果是,就將它刪除 if(arr[i].offsetLeft<0 || arr[i].offsetLeft > document.documentElement.clientWidth || arr[i].offsetTop > document.documentElement.clientHeight){ document.body.removeChild(arr[i]); // arr.splice(i,1); } } },30) }

5、最后別忘了我們的隨機數和隨機顏色的封裝

// 范圍隨機數 function random(max,min){ return Math.round(Math.random()*(max-min)+min); } // 隨機顏色 function randomColor(){ return 'rgb('+random(0,255)+','+random(0,255)+','+random(0,255)+')'; }

最后我們的煙花效果就實現了

今天的分享就到這里,希望大家能夠喜歡。

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

Javascript菜單特效大全

javascript仿QQ特效匯總

JavaScript時鐘特效匯總

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 美女一级毛片免费不卡视频 | 免费视频一区二区性色 | 国产黄色片在线观看 | 亚洲欧美日韩一区超高清 | 精品一区二区三区高清免费观看 | 成人a影片在线观看 | 男女啪啪抽搐一进一出小 | 久久午夜羞羞影院免费观看 | 国产福利视频一区二区微拍视频 | 日韩欧美精品一区二区 | 在线免费观看a级片 | 91sao在线看片水片 | 婷婷久久久五月综合色 | www.黄色| 欧美三级真做在线观看 | 49pao强力在线高清基地 | 国产精品国产三级在线专区 | 激情自拍视频 | 8888四色奇米在线观看不卡 | 黄色免费的视频 | 国产一级在线播放 | 亚洲啪啪网站 | 成人二区 | 清纯唯美亚洲综合五月天 | 99久久国产综合精品女不卡 | 免费成人毛片 | 国产精品视频在 | 日韩欧美亚洲综合一区二区 | 日本中文字幕乱码aa高清电影 | 成人欧美日韩高清不卡 | 久久精品国产精品亚洲婷婷 | jizz国产精品| 欧美一级看片免费观看视频在线 | 妞干网精品 | 夜夜夜精品视频免费 | 黄色1级| 天天躁夜夜躁很很躁2020 | 色播亚洲视频在线观看 | 亚洲精品一二三四区 | 国产呦精品一区二区三区网站 | 亚洲色图35p |