基于jQuery的烟花效果(运动相关)点击屏幕出烟花

 更新时间:2012年06月14日 13:19:06   转载 作者:  
基于jQuery的烟花效果(运动相关)点击屏幕出烟花 ,经测试不能点击过多,容易假死
效果图

核心代码:
复制代码 代码如下:

$(function(){
$(document).click(function(event){
/*1.创建DIV并插入到body当中
*2.设置其初始位置:TOP为屏幕的高度,left为鼠标点击时,鼠标的pageX值;
*/
//创建DIV
var $div = $("<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<20;i++){
$("body").append($("<div class='yh'></div>"));
}
/*烟花的颜色是随机的,而且是用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.length<6){
sjColor = "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<30;i++){
//判断鼠标点击时的右边烟花还是左边烟花
if(yhX<0){
downPw($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

相关文章

  • jQuery响应滚动条事件功能示例

    jQuery响应滚动条事件功能示例

    这篇文章主要介绍了jQuery响应滚动条事件功能,可实现针对滚动条状态的实时计算与响应功能,具有一定参考借鉴价值,需要的朋友可以参考下
    2017-10-10
  • Jquery跨域获得Json时invalid label错误的解决办法

    Jquery跨域获得Json时invalid label错误的解决办法

    这两天用 Jquery 跨域取数据的时候,经常碰到 invalid label 这个错误,十分的郁闷,老是取不到服务器端发送回来的 json 值,一般跨域用到的两个方法为:$.ajax 和 $.getJson
    2011-01-01
  • 详解jQuery的Cookie插件

    详解jQuery的Cookie插件

    本文对jQuery的Cookie插件的使用方法和具体实例进行系统介绍,有需要的朋友可以看下
    2016-11-11
  • 如何使用CSS3和JQuery easing 插件制作绚丽菜单

    如何使用CSS3和JQuery easing 插件制作绚丽菜单

    这篇文章主要介绍了如何使用CSS3和JQuery easing 插件制作绚丽菜单,这样做可以让有菜单的盒子滑出,并且弹出缩略图。在某些菜单项中我们还包含着有进一步链接的子菜单。取决于我们鼠标在菜单项上的停悬,子菜单将向左或向右滑动。,需要的朋友可以参考下
    2019-06-06
  • jquery 触发a链接点击事件解决方案

    jquery 触发a链接点击事件解决方案

    使用jquery为a连接绑定点击事件,具体代码如下,感兴趣的朋友可以参考下,希望可以帮助到你
    2013-05-05
  • jQuery中each()方法用法实例

    jQuery中each()方法用法实例

    这篇文章主要介绍了jQuery中each()方法用法,以实例形式详细分析了each()方法的功能、定义及使用技巧,非常具有实用价值,需要的朋友可以参考下
    2014-12-12
  • 使用jQuery动态设置单选框的选中效果

    使用jQuery动态设置单选框的选中效果

    这篇文章主要介绍了使用jQuery动态设置单选框的选中效果,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-12-12
  • jQueryUI DatePicker 添加时分秒

    jQueryUI DatePicker 添加时分秒

    本文主要介绍jQueryUI DatePicker添加时分秒的方法,简单实用,需要的朋友可以参考下。
    2016-06-06
  • jquery清空textarea等输入框实现代码

    jquery清空textarea等输入框实现代码

    jquery清空textarea等输入框在工作中很常见,接下来的代码简单实用,感兴趣的朋友可以参考下哈,希望对你有所帮助
    2013-04-04
  • Jquery提交表单 Form.js官方插件介绍

    Jquery提交表单 Form.js官方插件介绍

    我正在研究JQuery框架,其下的插件十分丰富,使用十分简单,功能也十分强大
    2012-03-03

最新评论