原生JS实现网页烟花动画效果——前端工程师必备技能!
2017-11-14 10:52
816 查看
原生js实现放烟花效果,点击鼠标,然后向四周扩散,最后自由落体效果!最简单的方法实现!
CSS代码:
[html] view
plain copy
*{
padding: 0px;
margin: 0px;
background: #000;
}
.firworks{
width: 6px;
height: 6px;
position: absolute;
}
js:代码:
[html] view
plain copy
<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.onclick=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();
}
}
相关文章推荐
- 原生JS实现网页烟花动画效果——前端工程师必备技能!
- JS实现超炫网页烟花动画效果的方法
- JS实现超炫网页烟花动画效果的方法
- 原生js简单实现jQuery的动画效果
- js实现横向百叶窗效果网页切换动画效果的方法
- js实现绿白相间竖向网页百叶窗动画切换效果
- 原生js利用鼠标滚轮实现滚动到当前页面实现动画效果
- 原生JS+HTML5实现跟随鼠标一起流动的粒子动画效果
- 原生Js实现简易烟花爆炸效果的方法
- 利用tween,使用原生js实现模块回弹动画效果
- 原生JS实现的雪花飘落动画效果
- 通过JS和CSS,实现网页加载中的动画效果
- 原生js实现jquery函数animate()动画效果的简单实例
- 原生JS实现的多个彩色小球跟随鼠标移动动画效果示例
- JS实现网页右侧带动画效果的伸缩窗口代码
- JS实现网页右侧带动画效果的伸缩窗口代码
- js实现绿白相间竖向网页百叶窗动画切换效果
- 原生JS实现CSS动画效果
- js实现横向百叶窗效果网页切换动画效果的方法
- 原生js实现网页顶部自动下拉/收缩广告效果