雪花飘落 jq版

10 篇文章 0 订阅

雪花飘落 js版

雪花下落的速度

snowflake.speed = [8000,10000];
速度为区间数值的随机数

雪花飘落的频率

使用setInterval定时器每800毫秒创建一个雪花
setInterval(“snowflake.snowflakeAdd()”,80);

图片路径自己替换下
<img src="images/christmas.jpg" style="width:100%;">

在这里插入图片描述

jq链接记得替换下
完整代码如下
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8" />
    <title>雪花下落</title>
</head>
<script src="../js/jquery-1.7.2.min.js"></script>
<style>
*{padding: 0;margin: 0;}
body,html{
	background:#000;
	width: 100%;
	height: 100%;
	overflow:hidden;
}
#snowflakeBox{height:100%; position:relative;}
</style>
<div id="snowflakeBox">
	<img src="images/christmas.jpg" style="width:100%;">
</div>
<script>

function snowflake(snowflakeBox)
{
	var snowflakeThis = this;
	this.speed = [8000,10000]; //雪花下落的速度
	// 定义块初始位置样式
	this.draw = function(odiv)
	{
		var speedH = 0;  
		var startPosLeft = Math.ceil(Math.random() * $(document).width());//设置雪花随机的开始x值的大小
		var oOpacity = this.getRandInt(6,10)/10;  //设置透明度
		var oLeft = startPosLeft+'px';
		var oTop = "0px"; 
		var oColor = "#fff";
		var oFontSize = this.getRandInt(12,25)+"px";
		odiv.css({"opacity":oOpacity,"left":oLeft,"color":oColor,"font-size":oFontSize,"top":oTop});
		
		odiv.animate({"top":snowflakeBox.height() + 50,"left":parseInt(oLeft) + this.getRandInt(-100,100)+"px","opacity":"0"},
			this.getRandInt(this.speed[0],this.speed[1]),
			function(){
				odiv.remove();
			});
	}
	// 新增块
	this.snowflakeAdd = function()
	{
		var snowflakeOne = "<div class='snowflakeItem'>"; 
		snowflakeOne += this.randIcon();
		snowflakeOne += "</div>";
		
		snowflakeBox.append(snowflakeOne);   //把创建好的div放进flame中
		that = snowflakeBox.children(".snowflakeItem:last-child");
		this.draw(that);  //执行obj的draw方法
	}
	
	// 随机雪花
	this.randIcon = function()
	{
		var icon = ["❅","❄","❅","❄","✽"];	
		return icon[this.getRandInt(0,4)];
	}
	
	// 随机整数
	this.getRandInt = function(start,end)
	{
		var rand = parseInt(Math.random() * (end - start + 1) + start);
		return rand;
	}
	return this;
} 

$(function(){
	var snowflakeBox= $("#snowflakeBox");
	var snowflakeFunc = snowflake(snowflakeBox);
	//雪花下落的速度
	snowflakeFunc.speed = [8000,10000]; 
	snowflakeFunc.snowflakeAdd();
	/*使用setInterval定时器每80毫秒创建一个雪花*/
	setInterval(snowflakeFunc.snowflakeAdd,8);  
})
</script>
<style> 
.snowflakeItem{ position:absolute;}
</style>
</html>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值