这篇文章主要介绍了JS如何实现简单的下雪特效,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
前言
首先看看项目结构,一张雪花图片,一个.html文件和 jquery-1.4.2.js
用到的雪花图片我放在这里了,或者可以直接用我上传到自己网站上的图片地址:http://haiyong.site/wp-content/uploads/2021/12/snow.png 开局一张图,内容全靠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" rel="external nofollow" 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)},10)
取消注释就会看到落下的雪会消失,如下图所示
喜欢看积雪就可以把它注释掉,预览效果像下面这样
到这里我们要实现的效果就完成了,如果运行时间过长可能会导致内存占用过多造成卡顿现象,可以将html代码中的最后一段注释里的内容取消注释,这样到下面的积雪就会慢慢淡出并且remove删除了,不过我觉得积雪也挺好看的,就没让它融化,像下面这样
感谢你能够认真阅读完这篇文章,希望小编分享的“JS如何实现简单的下雪特效”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!