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 相关文章推荐
jQuery实现div跟随鼠标移动
Aug 20 jQuery
jQuery导航条固定定位效果实例代码
May 26 jQuery
解决IE7中使用jQuery动态操作name问题
Aug 28 jQuery
jQuery实现table中两列CheckBox只能选中一个的示例
Sep 22 jQuery
jQuery实现的页面遮罩层功能示例【测试可用】
Oct 14 jQuery
jQuery与vue实现拖动验证码功能
Jan 30 jQuery
jQuery+Cookie实现切换皮肤功能【附源码下载】
Mar 25 jQuery
jQuery实现的滑块滑动导航效果示例
Jun 04 jQuery
JQuery Ajax动态加载Table数据的实例讲解
Aug 09 jQuery
jquery实现掷骰子小游戏
Oct 24 jQuery
JQuery常用简单动画操作方法回顾与总结
Dec 07 jQuery
jquery实现简单每周轮换的日历
Sep 10 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&amp;MYSQL分页原理及实现
2007/01/02 PHP
php检查字符串中是否有外链的方法
2015/07/29 PHP
PHP对象克隆clone用法示例
2016/09/28 PHP
PHP7导出Excel报ERR_EMPTY_RESPONSE解决方法
2019/04/16 PHP
CL vs ForZe BO5 第二场 2.13
2021/03/10 DOTA
jquery关于页面焦点的定位(文本框获取焦点时改变样式 )
2010/09/10 Javascript
基于jQuery判断两个元素是否有重叠部分的代码
2012/07/25 Javascript
Jquery实现页面加载时弹出对话框代码
2013/04/19 Javascript
javascript异步编程的4种方法
2014/02/19 Javascript
JS实现弹性菜单效果代码
2015/09/07 Javascript
轻量级jQuery插件slideBox实现带底栏轮播(焦点图)代码
2016/03/28 Javascript
关于JS中setTimeout()无法调用带参函数问题的解决方法
2016/06/21 Javascript
微信小程序 开发之顶部导航栏实例代码
2017/02/23 Javascript
layui弹出层按钮提交iframe表单的方法
2018/08/20 Javascript
浅谈JavaScript面向对象--继承
2019/03/20 Javascript
layui 实现表格某一列显示图标
2019/09/19 Javascript
vue使用map代替Aarry数组循环遍历的方法
2020/04/30 Javascript
elementui实现预览图片组件二次封装
2020/12/29 Javascript
用Python编写脚本使IE实现代理上网的教程
2015/04/23 Python
Python 列表排序方法reverse、sort、sorted详解
2016/01/22 Python
Python网络编程中urllib2模块的用法总结
2016/07/12 Python
Python3中类、模块、错误与异常、文件的简易教程
2017/11/20 Python
Python中循环引用(import)失败的解决方法
2018/04/22 Python
python 2.7.13 安装配置方法图文教程
2018/09/18 Python
Python 学习教程之networkx
2019/04/15 Python
python连接、操作mongodb数据库的方法实例详解
2019/09/11 Python
python将音频进行变速的操作方法
2020/04/08 Python
Etam艾格英国官网:法国著名女装品牌
2019/04/15 全球购物
澳大利亚设计师服装在线:MISHA
2019/10/07 全球购物
网络方面基础面试题
2012/11/16 面试题
小学语文课后反思精选
2014/04/25 职场文书
干部作风整顿自我剖析材料和整改措施
2014/09/18 职场文书
2015年元旦促销方案书
2014/12/09 职场文书
2015年元旦主持词开场白
2014/12/14 职场文书
六年级语文教学反思
2016/03/03 职场文书
Java常用工具类汇总 附示例代码
2021/06/26 Java/Android