当前位置: 移动技术网 > IT编程>开发语言>JavaScript > jQuery实现的模仿雨滴下落动画效果

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

2019年01月08日  | 移动技术网IT编程  | 我要评论

本文实例讲述了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代码运行工具:

在线html/css/javascript前端代码调试运行工具:

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

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

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网