jQuery实现的模仿雨滴下落动画效果


Posted in jQuery onDecember 11, 2018

本文实例讲述了jQuery实现的模仿雨滴下落动画效果。分享给大家供大家参考,具体如下:

效果如图:

 jQuery实现的模仿雨滴下落动画效果

实现思路:定时器每隔x秒生成宽高、下落速度(即动画执行时间)、left随机的div。

1.CSS:

body{
  overflow: hidden;/*这是为了防止出现滚动条*/
}
.com{
  border-radius: 0 50% 50% 50%;
  background: skyblue;
  transform: rotate(45deg);
  position: absolute;
  top: 0;
}

2.JS:

$(function(){
  var obj={
    maxW:100,//最大宽度
    minW:10,//最小宽度
    maxSpeed:10000,//最大速度,单位ms
    creat:400//创建雨滴个数的快慢,单位ms
  }
  rain(obj)
})
function rain(obj){
  var maxW=obj.maxW;
  var minW=obj.minW;
  var maxSpeed=obj.maxSpeed;
  var time=obj.creat;
  var maxLeft=$(window).width();
  var time1;
  var j=0;
  time1=setInterval(function(){
    var width=Math.random()*maxW;//随机宽度
    width=width.toFixed(2);
    if(width<minW){
      width=minW;
    }
    var left=Math.random()*maxLeft-width;//随机left值
    left=left.toFixed(2);
    if(left<0){
      left=0;
    }
    j++;
    var speed=Math.random()*maxSpeed;//随机速度
    var item='<div class="com rain'+j+'" style="left:'+left+'px;width:'+width+'px;height:'+width+'px"></div>';//创建雨滴
    $("body").append(item);
    move($(".rain"+j),speed);//雨滴移动
  },time)
}
function move(op,speed){
  var winH=$(window).height();
  var maxH=winH+op.height();//雨滴下落的高度,页面高度加上自身高度就能看到完全落到最底部
  op.animate({
    "top":maxH+"px"
  },speed,function(){
    op.remove();//删除该雨滴
  });
}

本来最开始想计算雨滴left和下落高度的最大值,以免出现滚动条,但是后来想直接body加个overflow:hidden不是更好么,省去多余的代码,效果还一样。

除了用JS实现,还可以用canvas来实现。

感兴趣的朋友可以使用如下工具测试上述代码运行效果:

在线HTML/CSS/JavaScript代码运行工具:
http://tools.3water.com/code/HtmlJsRun

在线HTML/CSS/JavaScript前端代码调试运行工具:
http://tools.3water.com/code/WebCodeRun

更多关于jQuery相关内容还可查看本站专题:《jQuery动画与特效用法总结》、《jQuery切换特效与技巧总结》、《jQuery扩展技巧总结》、《jQuery常用插件及用法总结》、《jQuery拖拽特效与技巧总结》、《jQuery表格(table)操作技巧汇总》、《jQuery常见经典特效汇总》及《jquery选择器用法总结》

希望本文所述对大家jQuery程序设计有所帮助。

jQuery 相关文章推荐
JavaScript使用链式方法封装jQuery中CSS()方法示例
Apr 07 jQuery
jQuery日期范围选择器附源码下载
May 23 jQuery
jquery与js实现全选功能的区别
Jun 11 jQuery
基于Jquery Ajax type的4种类型(详解)
Aug 02 jQuery
jq源码解析之绑在$,jQuery上面的方法(实例讲解)
Oct 13 jQuery
浅谈jquery fullpage 插件增加头部和版权的方法
Mar 20 jQuery
基于jQuery使用Ajax动态执行模糊查询功能
Jul 05 jQuery
js/jQuery实现全选效果
Jun 17 jQuery
jQuery中DOM操作原则实例分析
Aug 01 jQuery
jQuery Raty星级评分插件使用方法实例分析
Nov 25 jQuery
jquery实现拖拽添加元素功能
Dec 01 jQuery
jQuery实现电梯导航模块
Dec 22 jQuery
jQuery实现数字自动增加或者减少的动画效果示例
Dec 11 #jQuery
JQuery实现ajax请求的示例和注意事项
Dec 10 #jQuery
jQuery选择器选中最后一个元素,倒数第二个元素操作示例
Dec 10 #jQuery
jQuery+css last-child实现选择最后一个子元素操作示例
Dec 10 #jQuery
JQuery Ajax执行跨域请求数据的解决方案
Dec 10 #jQuery
jQuery时间戳和日期相互转换操作示例
Dec 07 #jQuery
超好用的jQuery分页插件jpaginate用法示例【附源码下载】
Dec 06 #jQuery
You might like
PHP+DBM的同学录程序(3)
2006/10/09 PHP
PHP中usort在值相同时改变原始位置问题的解决方法
2011/11/27 PHP
php并发对MYSQL造成压力的解决方法
2013/02/21 PHP
用PHP实现浏览器点击下载TXT文档的方法详解
2013/06/02 PHP
PHP 7.0.2 正式版发布
2016/01/08 PHP
浅析php中array_map和array_walk的使用对比
2016/11/20 PHP
关于php几种字符串连接的效率比较(详解)
2017/02/22 PHP
详解CSS样式中的 !important * _ 符号
2021/03/09 HTML / CSS
基于jquery的仿百度的鼠标移入图片抖动效果
2010/09/17 Javascript
Js获取数组最大和最小值示例代码
2013/10/29 Javascript
jQuery(js)获取文字宽度(显示长度)示例代码
2013/12/31 Javascript
JS实现的页面自定义滚动条效果
2015/10/26 Javascript
使用Bootstrap框架制作查询页面的界面实例代码
2016/05/27 Javascript
基于jQuery实现点击列表加载更多效果
2016/05/31 Javascript
Bootstrap分页插件之Bootstrap Paginator实例详解
2016/10/15 Javascript
js捆绑TypeScript声明文件的方法教程
2018/04/13 Javascript
angularjs $http调用接口的方式详解
2018/08/13 Javascript
JavaScript制作3D旋转相册
2020/08/02 Javascript
JavaScript 面向对象程序设计详解【类的创建、实例对象、构造函数、原型等】
2020/05/12 Javascript
Python实现识别手写数字 简易图片存储管理系统
2018/01/29 Python
linux下python使用sendmail发送邮件
2018/05/22 Python
Python 查找list中的某个元素的所有的下标方法
2018/06/27 Python
Python基于matplotlib画箱体图检验异常值操作示例【附xls数据文件下载】
2019/01/07 Python
对Python使用mfcc的两种方式详解
2019/01/09 Python
Python简单实现词云图代码及步骤解析
2020/06/04 Python
Python Django路径配置实现过程解析
2020/11/05 Python
CSS3 重置iphone浏览器按钮input,select等表单元素的默认样式
2014/10/11 HTML / CSS
幼师求职自荐信
2014/05/31 职场文书
相亲大会策划方案
2014/06/05 职场文书
项目工作说明书
2014/07/29 职场文书
岳庙导游词
2015/02/04 职场文书
人事任命通知
2015/04/20 职场文书
2015年教师国培感言
2015/08/01 职场文书
七年级语文教学反思
2016/03/03 职场文书
2016年法制宣传月活动总结
2016/04/01 职场文书
js实现上传图片到服务器
2021/04/11 Javascript