HTML+CSS+JS如何实现雪花飘扬

发布时间:2022-01-13 09:48:15 作者:小新
来源:亿速云 阅读:155

小编给大家分享一下HTML+CSS+JS如何实现雪花飘扬,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

很多南方的小伙伴可能没怎么见过或者从来没见过下雪,今天我给大家带来一个小Demo,模拟了下雪场景,首先让我们看一下运行效果


HTML+CSS+JS如何实现雪花飘扬

首先看看项目结构,一张雪花图片,一个.html文件和 jquery-1.4.2.js

HTML+CSS+JS如何实现雪花飘扬

用到的雪花图片我放在这里了,或者可以直接用图片地址:https://img.php.cn/upload/article/000/000/024/61dea8bfbe598211.png 开局一张图,内容全靠JS。

HTML+CSS+JS如何实现雪花飘扬

HTML代码

下面这是 html 里的内容,没啥东西

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>海拥| 雪一片一片</title>
		<meta name="viewport" content="width=device-width,user-scalable=no">
		<meta name="keywords" content="雪一片一片" />
		<meta name="description" content="工具 | 雪一片一片;立志打造一个拥有100个小游戏的摸鱼网站。Made By Haiyong,技术支持——海拥" /> 
		<meta name="author" content="海拥(http://haiyong.site/moyu)" />
		<meta name="copyright" content="海拥(http://haiyong.site/moyu)" />
		<link rel="icon" href="http://haiyong.site/wp-content/uploads/2021/07/cropped-59255587-1-192x192.jpg" sizes="192x192" />
		<style type="text/css">
			body{
				background-color: #000000;
				margin: 0;/* 去掉自带的外边距 */
			}
			img{
				position: absolute;
			}
		</style>
	</head>
	<body>
		<script src="js/jquery-1.4.2.js" type="text/javascript" charset="utf-8"></script>		
	</body>
</html>

JS代码:

首先开启定时器添加雪花图片,这里的<img src='images/snow.png'>可以改成<img src='http://haiyong.site/wp-content/uploads/2021/12/snow.png'>

setInterval(function(){
var img = $("<img src='images/snow.png'>");
$("body").append(img);

这里设置雪花的尺寸为10-20px,下面的公式即表示(0-10 + 10)px

var size = parseInt(Math.random()*11)+10;
img.css("width",size+"px");

得到屏幕宽度

var w = $(window).width();

取值范围应该是0-屏幕宽度-雪花宽度

var left =parseInt(Math.random()*(w-size));

把得到的随机1eft给到图片

img.css("left",left+"px");

添加雪花移动的动画,得到雪花移动的距离 = 屏幕高度-雪花尺寸

var top = $(window).height()-size;

下面注释中的代码是用来清除缓存的,可加可不加。

img.animate({"top":top+"px"},size*100)
/* .fadeOut(1000,function(){
	//当动画完成时执行此代码,清除缓存
	img.remove();
	//console.log($("img").length);
}); */
},10)

取消注释就会看到落下的雪会消失,如下图所示

HTML+CSS+JS如何实现雪花飘扬

喜欢看积雪就可以把它注释掉,预览效果像下面这样

HTML+CSS+JS如何实现雪花飘扬

到这里我们要实现的效果就完成了,如果运行时间过长可能会导致内存占用过多造成卡顿现象,可以将html代码中的最后一段注释里的内容取消注释,这样到下面的积雪就会慢慢淡出并且remove删除了,不过我觉得积雪也挺好看的,就没让它融化,像下面这样:

HTML+CSS+JS如何实现雪花飘扬

看完了这篇文章,相信你对“HTML+CSS+JS如何实现雪花飘扬”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

推荐阅读:
  1. 如何使用html+css+js实现弹球游戏
  2. Canvas实现动态的雪花效果

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

html css js

上一篇:javascript如何删除元素的hidden属性

下一篇:php如何将几分几秒转换成秒

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》