搜索
首页web前端js教程基于jQuery的烟花效果(运动相关)点击屏幕出烟花_jquery

效果图
基于jQuery的烟花效果(运动相关)点击屏幕出烟花_jquery
核心代码:

复制代码 代码如下:

$(function(){
$(document).click(function(event){
/*1.创建DIV并插入到body当中
*2.设置其初始位置:TOP为屏幕的高度,left为鼠标点击时,鼠标的pageX值;
*/
//创建DIV
var $div = $("
");
var eLeft = event.pageX;
var etop = event.pageY;
var cHeight = document.documentElement.clientHeight;
//设定颜色、大小,和其初始化的位置
$div.css({"width":4,"height":15,"background-color":"red","top":cHeight,"left":eLeft});
//插入到页面的body当中去;
$("body").append($div);
//不要出现滚动条
$("body").css("overflow","hidden");
//让DIV向上移动,并且移动到鼠标位置后,删除这个DIV元素,之后执行烟花效果;
$div.animate({"top":etop},700,function(){
//移除DIV
$(this).remove();
/*烟花效果
*1.烟花是很多个DIV构成
*2.每个烟花的颜色不一样
*3.烟花的位置也不一样
*4.烟花散开方向不一样
*5.烟花有下坠感觉
*/
//用循环造建很多个DIV,来表示烟花
for(i=0;i$("body").append($("
"));
}
/*烟花的颜色是随机的,而且是用16进制表示色值,所以用随机数结合16进制;
*16进制的最大值ffffff,转换成十进制16777215;
*Math.random()*16777215公式可以得到0-16777215之间的数,因为是小数,所以要用到取整;
*Math.ceil(Math.random()*16777215)生成一个在颜色值范围内的,随机的十进制值;
*Math.random()*9+1公式可以得到1-10之间的数,以此类推
*.toString(16)方法,是把得到的十进制,转换成16进制,也就是随机的颜色值了;
*/

var sjColor = ""
function changColor(){
sjColor = Math.ceil(Math.random()*16777215).toString(16)//;
//当这个产生的随机的颜色值,不足6位数的进候,需要补齐,又不改变其值,所以要在这个数的前面加零;
while(sjColor.lengthsjColor = "0"+sjColor;
}
}


//设置烟花DIV的颜色和位置、散开,坠落
$(".yh").css({"width":3,"height":3,"top":etop,"left":eLeft});
/*烟花散开要设左和上
*Math.random()*20-20这里要减20,是因为烟花是从中心点的左右散开的,
*最小随机数时0-10 = -10,最大随机数时20-10=10;所以就是正负10之间
*/
$(".yh").each(function(index, element) {
var $this = $(this);
changColor()
var yhX = Math.random()*400-200;
var yhY = Math.random()*600-300;
$this.
css({"background-color":"#"+sjColor,"width":3,"height":3}).
animate({"top":etop-yhY,"left":eLeft-yhX},500);//散开
for(i=0;i//判断鼠标点击时的右边烟花还是左边烟花
if(yhXdownPw($this,"+");//右下坠
}else{
downPw($this,"-");//左下坠
}
}

//下坠效果,即同时改变烟花元素的X和Y,会有抛物线感觉,然后完成动画后,删除这个烟花元素
function downPw(odiv,f){
odiv.animate({"top":"+=30","left":f+"=4"},50,function(){
setTimeout(function(){odiv.remove()},2000);
})
}
});
});
})
})

一、功能
  点击页面出现上图的效果,并下坠。
二、功能分析
  1.点击时创建DIV并插入到body当中
  2.烟花是很多个DIV构成,所以同时也要创建这些DIV
  3.每个烟花的颜色不一样,所以需要随机函数处理颜色值
  4.烟花的位置也不一样,所以也需要随机函数处理位置
  5.烟花散开方向不一样
  6.烟花要下坠感觉
三、总结:
  3.1.随机数 Math.random()零到一之间的数;
    3.11Math.random()乘以任意一个数,结果就是0-这个乘数之间的值,
      Math.random()*9 结果就是0-9之间的数
    3.12如果要让起始值为别一个指定的数,不为零,就加上这一个数;
      Math.random()*8+2 结果就是2-10之间的数
    3.13如果要想正负之间的数,就减去乘数的一半
      Math.random()*8-4,其结果就是+4和-4之间的数

  3.2运动核心
    3.21就是让元素在当前页面中的X坐标,或Y坐标 发生改变(加、减、乘、除等,只要能让这个值改变的运算,都行)
    3.22怎么改变才能看起来是运动的呢?
      每次改变时,都是参考元素当前的X或Y坐标。(因为每一次的改变,这个元素的坐标就会变化)所以始终都要获取到当前这个元素改变之后的X或Y坐标值。

  3.3随机颜色值
    颜色值,是十六进制数。而这个值也是有范围的,所以我们要先取得其范围。
    000000-FFFFFF.
    然后要转换成十进制的范围
    0-16777215
    有了这个范围就可以利用随机数,生成在这个范围内的色值了。当然最后还是要转成十六进制,并且不要忘记在色值前面加"#"号

  3.4下坠感
    其实就是让元素有,一个抛物线的变化,即让元素的X和Y的值,同时间变化。

  (在使用setTimeout的时候,里面的this,不要指向错了!~~)

在线演示:http://demo.jb51.net/js/2012/myyanhua/
打包下载:myyanhua_jb51.rar
声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
Python vs. JavaScript:开发环境和工具Python vs. JavaScript:开发环境和工具Apr 26, 2025 am 12:09 AM

Python和JavaScript在开发环境上的选择都很重要。1)Python的开发环境包括PyCharm、JupyterNotebook和Anaconda,适合数据科学和快速原型开发。2)JavaScript的开发环境包括Node.js、VSCode和Webpack,适用于前端和后端开发。根据项目需求选择合适的工具可以提高开发效率和项目成功率。

JavaScript是用C编写的吗?检查证据JavaScript是用C编写的吗?检查证据Apr 25, 2025 am 12:15 AM

是的,JavaScript的引擎核心是用C语言编写的。1)C语言提供了高效性能和底层控制,适合JavaScript引擎的开发。2)以V8引擎为例,其核心用C 编写,结合了C的效率和面向对象特性。3)JavaScript引擎的工作原理包括解析、编译和执行,C语言在这些过程中发挥关键作用。

JavaScript的角色:使网络交互和动态JavaScript的角色:使网络交互和动态Apr 24, 2025 am 12:12 AM

JavaScript是现代网站的核心,因为它增强了网页的交互性和动态性。1)它允许在不刷新页面的情况下改变内容,2)通过DOMAPI操作网页,3)支持复杂的交互效果如动画和拖放,4)优化性能和最佳实践提高用户体验。

C和JavaScript:连接解释C和JavaScript:连接解释Apr 23, 2025 am 12:07 AM

C 和JavaScript通过WebAssembly实现互操作性。1)C 代码编译成WebAssembly模块,引入到JavaScript环境中,增强计算能力。2)在游戏开发中,C 处理物理引擎和图形渲染,JavaScript负责游戏逻辑和用户界面。

从网站到应用程序:JavaScript的不同应用从网站到应用程序:JavaScript的不同应用Apr 22, 2025 am 12:02 AM

JavaScript在网站、移动应用、桌面应用和服务器端编程中均有广泛应用。1)在网站开发中,JavaScript与HTML、CSS一起操作DOM,实现动态效果,并支持如jQuery、React等框架。2)通过ReactNative和Ionic,JavaScript用于开发跨平台移动应用。3)Electron框架使JavaScript能构建桌面应用。4)Node.js让JavaScript在服务器端运行,支持高并发请求。

Python vs. JavaScript:比较用例和应用程序Python vs. JavaScript:比较用例和应用程序Apr 21, 2025 am 12:01 AM

Python更适合数据科学和自动化,JavaScript更适合前端和全栈开发。1.Python在数据科学和机器学习中表现出色,使用NumPy、Pandas等库进行数据处理和建模。2.Python在自动化和脚本编写方面简洁高效。3.JavaScript在前端开发中不可或缺,用于构建动态网页和单页面应用。4.JavaScript通过Node.js在后端开发中发挥作用,支持全栈开发。

C/C在JavaScript口译员和编译器中的作用C/C在JavaScript口译员和编译器中的作用Apr 20, 2025 am 12:01 AM

C和C 在JavaScript引擎中扮演了至关重要的角色,主要用于实现解释器和JIT编译器。 1)C 用于解析JavaScript源码并生成抽象语法树。 2)C 负责生成和执行字节码。 3)C 实现JIT编译器,在运行时优化和编译热点代码,显着提高JavaScript的执行效率。

JavaScript在行动中:现实世界中的示例和项目JavaScript在行动中:现实世界中的示例和项目Apr 19, 2025 am 12:13 AM

JavaScript在现实世界中的应用包括前端和后端开发。1)通过构建TODO列表应用展示前端应用,涉及DOM操作和事件处理。2)通过Node.js和Express构建RESTfulAPI展示后端应用。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )专业的PHP集成开发工具