新用户注册入口 老用户登录入口

[转载]HTML+CSS+JS制作炫酷【烟花特效】

文章作者:转载 更新时间:2023-02-15 08:02:38 阅读数量:274
文章标签:烟花特效HTMLCSS鼠标点击效果分散形烟花圆形烟花
本文摘要:该文章详细介绍了利用HTML、CSS和JavaScript制作鼠标点击触发的烟花特效,包括分散形、圆形及爱心形三种烟花效果。每种烟花均提供相应的HTML结构、CSS样式及JS代码,且在黑色背景上展示出绚丽视觉效果。读者可在线下载源码(https://gitee.com/huang_weifu/JavaScript_demo.git),通过实践学习并实现这些炫酷烟花特效。
转载文章

本篇文章为转载内容。原文链接:https://blog.csdn.net/huangwfu/article/details/128754023。

该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。

作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。

如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。

文章目录

    • 制作炫酷烟花特效
    • 一、普通烟花(分散形)
      • HTML代码
      • CSS代码
      • JS代码
    • 二、圆形烟花
      • HTML代码
      • CSS代码
      • JS代码
    • 三、爱心形烟花
      • HTML代码
      • CSS代码
      • JS代码
    • 四、源码获取
      • 在线下载

制作炫酷烟花特效

💡本篇内容使用html+css+js制作鼠标点击出现烟花效果,分别介绍了分散型烟花,圆形烟花和爱心形烟花,爱心形烟花算法比较复杂,需要源码的小伙伴可以通过文章末尾链接下载。

一、普通烟花(分散形)

效果展示

请添加图片描述

HTML代码

引入js 文件

<script type="text/javascript" src="buffermove1.js"></script>

CSS代码

创建一个黑色背景

<style type="text/css">*{padding: 0px;margin: 0px;}body{background: #000;width: 100%;height:100%;overflow: hidden;}</style>

JS代码

<script type="text/javascript">//this绑定的属性可以在整个构造函数内部都可以使用,而变量只能在函数内部使用。function Fireworks(x,y){//x,y鼠标的位置this.x=x;this.y=y;var that=this;//1.创建烟花。this.ceratefirework=function(){this.firework=document.createElement('div');//整个构造函数内部都可以使用this.firework.style.cssText=`width:5px;height:5px;background:#fff;position:absolute;left:${this.x}px;top:${document.documentElement.clientHeight}px;`;document.body.appendChild(this.firework);this.fireworkmove();};//2.烟花运动和消失this.fireworkmove=function(){buffermove(this.firework,{top:this.y},function(){document.body.removeChild(that.firework);//烟花消失,碎片产生that.fireworkfragment();});};//3.创建烟花的碎片this.fireworkfragment=function(){for(var i=0;i<this.ranNum(30,60);i++){this.fragment=document.createElement('div');this.fragment.style.cssText=`width:5px;height:5px;background:rgb(${this.ranNum(0,255)},${this.ranNum(0,255)},${this.ranNum(0,255)});position:absolute;left:${this.x}px;top:${this.y}px;`;document.body.appendChild(this.fragment);this.fireworkboom(this.fragment);//将当前创建的碎片传过去,方便运动和删除}}//4.碎片运动this.fireworkboom=function(obj){//obj:创建的碎片//设点速度(值不同,正负符号不同)var speedx=parseInt((Math.random()>0.5?'-':'')+this.ranNum(1,15));var speedy=parseInt((Math.random()>0.5?'-':'')+this.ranNum(1,15));//初始速度var initx=this.x;var inity=this.y;obj.timer=setInterval(function(){//一个盒子运动initx+=speedx;inity+=speedy;if(inity>=document.documentElement.clientHeight){clearInterval(obj.timer);document.body.removeChild(obj);}obj.style.left=initx+'px';obj.style.top=inity+'px';},20);}//随机方法this.ranNum=function (min,max){return Math.round(Math.random()*(max-min))+min;};}document.removed=function(ev){var ev=ev||window.event;new Fireworks(ev.clientX,ev.clientY).ceratefirework();}
</script>

二、圆形烟花

效果展示
在这里插入图片描述

HTML代码

引入js 文件

<script type="text/javascript" src="buffermove1.js"></script>

CSS代码

创建一个黑色背景

<style type="text/css">*{padding: 0px;margin: 0px;}body{background: #000;width: 100%;height:100%;overflow: hidden;}</style>

JS代码

<script type="text/javascript">//this绑定的属性可以在整个构造函数内部都可以使用,而变量只能在函数内部使用。function Fireworks(x,y){//x,y鼠标的位置this.x=x;this.y=y;var that=this;//1.创建烟花。this.ceratefirework=function(){this.firework=document.createElement('div');//整个构造函数内部都可以使用this.firework.style.cssText=`width:5px;height:5px;background:#fff;position:absolute;left:${this.x}px;top:${document.documentElement.clientHeight}px;`;document.body.appendChild(this.firework);this.fireworkmove();};//2.烟花运动和消失this.fireworkmove=function(){var that=this;buffermove(this.firework,{top:this.y},function(){document.body.removeChild(that.firework);//烟花消失,碎片产生that.fireworkfragment();});};//3.创建烟花的碎片this.fireworkfragment=function(){var num=this.ranNum(30,60);//盒子的个数this.perRadio=2*Math.PI/num;//弧度for(var i=0;i<num;i++){this.fragment=document.createElement('div');this.fragment.style.cssText=`width:5px;height:5px;background:rgb(${this.ranNum(0,255)},${this.ranNum(0,255)},${this.ranNum(0,255)});position:absolute;left:${this.x}px;top:${this.y}px;`;document.body.appendChild(this.fragment);this.fireworkboom(this.fragment,i);//将当前创建的碎片传过去,方便运动和删除}}//4.碎片运动this.fireworkboom=function(obj,i){//obj:创建的碎片var r=10;obj.timer=setInterval(function(){//一个盒子运动r+=4;if(r>=200){clearInterval(obj.timer);document.body.removeChild(obj);}obj.style.left=that.x+Math.sin(that.perRadio*i)*r+'px';obj.style.top=that.y+Math.cos(that.perRadio*i)*r+'px';},20);}//随机方法this.ranNum=function (min,max){return Math.round(Math.random()*(max-min))+min;};}document.removed=function(ev){var ev=ev||window.event;new Fireworks(ev.clientX,ev.clientY).ceratefirework();}</script>

三、爱心形烟花

效果展示
在这里插入图片描述

HTML代码

引入js 文件

<script type="text/javascript" src="buffermove1.js"></script>

CSS代码

创建一个黑色背景

<style type="text/css">*{padding: 0px;margin: 0px;}body{background: #000;width: 100%;height:100%;overflow: hidden;}</style>

JS代码

<script type="text/javascript">//this绑定的属性可以在整个构造函数内部都可以使用,而变量只能在函数内部使用。function Fireworks(x,y){//x,y鼠标的位置this.x=x;this.y=y;var that=this;//1.创建烟花。this.ceratefirework=function(){this.firework=document.createElement('div');//整个构造函数内部都可以使用this.firework.style.cssText=`width:5px;height:5px;background:#fff;position:absolute;left:${this.x}px;top:${document.documentElement.clientHeight}px;`;document.body.appendChild(this.firework);this.fireworkmove();};//2.烟花运动和消失this.fireworkmove=function(){buffermove(this.firework,{top:this.y},function(){document.body.removeChild(that.firework);//烟花消失,碎片产生that.fireworkfragment();});};//3.创建烟花的碎片this.fireworkfragment=function(){var num=this.ranNum(30,60);//盒子的个数this.perRadio=2*Math.PI/num;//弧度for(var i=0;i<num;i++){this.fragment=document.createElement('div');this.fragment.style.cssText=`width:5px;height:5px;background:rgb(${this.ranNum(0,255)},${this.ranNum(0,255)},${this.ranNum(0,255)});position:absolute;left:${this.x}px;top:${this.y}px;`;document.body.appendChild(this.fragment);this.fireworkboom(this.fragment,i);//将当前创建的碎片传过去,方便运动和删除}}//x=16*Math.pow(sint,3);  //Math.sin(perRadio*i)//y=13Cost-5*Cos2t-2*Cos3t-Cos4t//4.碎片运动this.fireworkboom=function(obj,i){//obj:创建的碎片var r=0.1;obj.timer=setInterval(function(){//一个盒子运动r+=0.4;if(r>=10){clearInterval(obj.timer);document.body.removeChild(obj);}obj.style.left=that.x+16*Math.pow(Math.sin(that.perRadio*i),3)*r+'px';obj.style.top=that.y-(13*Math.cos(that.perRadio*i)-5*Math.cos(2*that.perRadio*i)-2*Math.cos(3*that.perRadio*i)-Math.cos(4*that.perRadio*i))*r+'px';},20);}//随机方法this.ranNum=function (min,max){return Math.round(Math.random()*(max-min))+min;};}document.removed=function(ev){var ev=ev||window.event;new Fireworks(ev.clientX,ev.clientY).ceratefirework();}</script>

四、源码获取

在线下载

资源链接:https://gitee.com/huang_weifu/JavaScript_demo.git
在这里插入图片描述

本篇文章为转载内容。原文链接:https://blog.csdn.net/huangwfu/article/details/128754023。

该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。

作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。

如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。

相关阅读
文章标题:[转载][洛谷P1082]同余方程

更新时间:2023-02-18
[转载][洛谷P1082]同余方程
文章标题:[转载]webpack优化之HappyPack实战

更新时间:2023-08-07
[转载]webpack优化之HappyPack实战
文章标题:[转载]oracle 同时更新多表,在Oracle数据库中同时更新两张表的简单方法

更新时间:2023-09-10
[转载]oracle 同时更新多表,在Oracle数据库中同时更新两张表的简单方法
文章标题:[转载][Unity] 包括场景互动与射击要素的俯视角闯关游戏Demo

更新时间:2024-03-11
[转载][Unity] 包括场景互动与射击要素的俯视角闯关游戏Demo
文章标题:[转载]程序员也分三六九等?等级差异,一个看不起一个!

更新时间:2024-05-10
[转载]程序员也分三六九等?等级差异,一个看不起一个!
文章标题:[转载]海贼王 动漫 全集目录 分章节 精彩打斗剧集

更新时间:2024-01-12
[转载]海贼王 动漫 全集目录 分章节 精彩打斗剧集
名词解释
作为当前文章的名词解释,仅对当前文章有效。
HTML(Hypertext Markup Language)HTML是一种标记语言,用于创建和设计网页内容结构。在本文语境中,HTML代码被用来构建烟花特效的基本页面结构,定义元素的位置、层级关系以及基础样式,如黑色背景的设置。
CSS(Cascading Style Sheets)CSS是层叠样式表的简称,是一种样式表语言,用于描述HTML或XML文档的呈现方式,包括布局、颜色、字体等视觉效果。在制作炫酷烟花特效的过程中,CSS负责为烟花提供动画效果所需的样式规则,比如设定烟花的颜色、大小、旋转、透明度变化等属性,以实现不同的形状与动态效果。
JavaScriptJavaScript是一种轻量级的解释型编程语言,常用于给网页添加交互式功能。在该篇文章中,JavaScript扮演了关键角色,编写算法控制烟花的生成、运动轨迹、爆炸形态以及消失等动态过程,使得鼠标点击后能够触发烟花特效,并根据不同类型(分散形、圆形、爱心形)产生相应的视觉效果。
WebGL虽然文章未直接提及WebGL,但在类似场景下,它是一个重要的技术名词。WebGL是一种JavaScript API,用于在任何兼容的Web浏览器中呈现交互式2D、3D图形而无需插件。在更复杂的烟花特效实现中,开发者可以利用WebGL结合着色器(shader)进行高性能的三维立体烟花渲染,模拟更加真实和细腻的烟花爆炸效果。
延伸阅读
作为当前文章的延伸阅读,仅对当前文章有效。
在探索了如何使用HTML、CSS和JavaScript制作炫酷的烟花特效之后,我们发现此类动态视觉效果在网页设计与交互体验中扮演着日益重要的角色。近期,随着WebGL和Canvas API的不断优化与发展,前端开发者能够创造出更加细腻且真实的3D烟花动画,甚至可以模拟大规模烟花汇演场景。
例如,Mozilla Hacks社区近期发布的一篇技术文章“利用WebGL打造逼真的3D烟花模拟”深入探讨了如何结合物理引擎与WebGL技术,以实时渲染的方式生成随风力、重力等因素影响的立体烟花效果。同时,文中还分享了如何通过Shader编程实现复杂的烟花纹理及粒子系统,使得每一朵烟花绽放的过程都具有独一无二的美感。
此外,随着元宇宙概念的兴起,虚拟空间中的庆祝活动也开始广泛应用定制化的烟花特效。《虚拟世界中的烟火:从2D到3D的演变》一文就介绍了在VR/AR环境中,开发团队如何根据用户的空间感知和交互方式,设计出既符合现实物理规律又能满足沉浸式体验需求的烟花特效。
不仅如此,烟花特效也在游戏开发领域得到广泛应用。许多在线游戏会在特定节日或活动中添加烟花元素,以此提升玩家的游戏体验和情感共鸣。例如,《游戏开发者杂志》最近一篇报道揭示了游戏设计师如何将烟花特效融入游戏剧情与任务设定,让玩家在游戏中感受到浓厚的节庆氛围。
综上所述,在不断发展的前端技术和新兴应用场景下,烟花特效的设计与实现正迎来更多的可能性与挑战,值得广大开发者持续关注和研究。
知识学习
实践的时候请根据实际情况谨慎操作。
随机学习一条linux命令:
lastlog - 显示所有用户的最后登录时间及相关信息。
随便看看
拉到页底了吧,随便看看还有哪些文章你可能感兴趣。
可自定义logo的jQuery生成二维码插件 01-03 jquery每日签到日历插件 10-10 高度可定制的jQuery瀑布流网格布局插件 03-15 Consul中服务实例自动注销问题解析:健康检查、稳定性与Agent配置的影响及解决策略 01-22 怎么看mysql 的安装路径 12-31 jquery横向手风琴效果 12-23 蓝色数码电子产品销售HTML5网站模板 12-14 jQuery和CSS3汉堡包导航菜单打开动画特效 10-19 python模拟生存游戏 10-08 本次刷新还10个文章未展示,点击 更多查看。
jQuery.eraser-实现橡皮擦擦除功能的jquery插件 05-26 Netty中ChannelNotRegisteredException异常处理:理解原因与确保Channel注册状态的方法示例 05-16 响应式游戏开发类企业前端cms模板下载 05-02 精美的花甲美食网站HTML模板下载 03-09 soulmate粉色干净浪漫唯美婚礼单页响应式网站模板 03-07 Vue.js项目中proxyTable数据转发遭遇504错误:服务器响应时间与网络连接问题排查及解决方案 03-05 SpringCloud服务路由配置错误与失效:识别问题、排查步骤及组件解析这个涵盖了的核心内容,包括SpringCloud框架下的服务路由配置错误失效问题的识别,以及涉及到的服务注册中心、Gateway、Zuul等组件的功能解析和故障排查的具体步骤。同时,字数控制在了50个字以内,满足了要求。 03-01 css水平线长度设置 02-11 [转载]Proxy 、Relect、响应式 01-11 蓝色响应式软件营销代理公司网站静态模板 01-06 python正太分布校验 01-05
时光飞逝
"流光容易把人抛,红了樱桃,绿了芭蕉。"