原生JS实现网页烟花动画效果——前端工程师必备技能!

原创 2016年11月12日 18:34:32

原生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.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();
	}
}
</script>

(我吃酸萝卜 新浪微博http://www.weibo.com/wcslb          ---李帅醒著)


版权声明:本文为博主 我吃酸萝卜/李帅醒 原创, 未经博主允许不得转载。新浪微博@我吃酸萝卜

相关文章推荐

貌似3D效果的JS烟花特效代码

貌似3D效果的JS烟花特效代码,烟花展开的一瞬间,很漂亮,很有空间感,漂漂洒洒,慢慢退去。...

传说中的Java烟花程序

相信看到这些美丽的烟花图片,你会发现原来java也可以这么美 并且还是用awt做的,更是实属不易,但在此声明此程序并非出自本人之手 只是个人觉得这么美好的东西不应该被埋没于时间中,应该让更多人知道...

一个漂亮的java烟花程序

一个有趣的java漂亮烟花小程序

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

JS原生 之------放烟花喽

js原生 烟花效果 运动的运用

JS实现鼠标点击处烟花爆炸效果

JS实现鼠标点击处烟花爆炸效果(面向对象版) 程序由网上开源“JS实现放烟花效果”代码改编,实现在鼠标点击处出现烟花爆炸效果。...
  • xxx_qz
  • xxx_qz
  • 2017年02月22日 21:13
  • 240

前端工程师必备的PS技能——切图篇(笔记)

新建设置自定义:(可存储为预设) 宽度 1920像素 高度 2000像素(可改) 分辨率 72像素/英寸 颜色模式 RGB颜色 背景内容 透明视图设置视图-显示-智能参考线 视图-标尺 ...
  • c__333
  • c__333
  • 2015年10月13日 19:20
  • 2038

前端工程师必备的PS技能——切图篇

Photoshop界面设置 移动工具快捷键——v 注意自动选择选项 智能参考线——视图->显示 标尺——Ctrl+R 窗口->信息(面板选项中,第二种颜色信息模式为RGB颜色,标尺单位...

作为一名前端工程师——这些技能你掌握多少?

一框架与组件 二构建生态一、框架与组件bootstrap等UI框架设计与实现 伸缩布局:grid网格布局 基础UI样式:元素reset、按钮、图片、菜单、表单 组件UI样式:按钮组、字体图标、下拉菜单...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:原生JS实现网页烟花动画效果——前端工程师必备技能!
举报原因:
原因补充:

(最多只允许输入30个字)