-
前端案例·程序员的浪漫:流星雨背景
- 网站名称:前端案例·程序员的浪漫:流星雨背景
- 网站分类:技术文章
- 收录时间:2025-06-09 21:10
- 网站地址:
“前端案例·程序员的浪漫:流星雨背景” 网站介绍
如果文章对你有收获,还请不要吝啬【点赞收藏评论】三连哦,你的鼓励将是我成长助力之一!谢谢!
(1)方式1:简单版本
【1】先看实现效果
【2】再看完整代码
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<!--
CSS部分:
body设置为黑色背景,并隐藏溢出内容。
.meteor类定义了流星的样式,使用linear-gradient实现流星的渐变效果。
@keyframes meteor定义了流星从屏幕顶部移动到底部的动画,并逐渐消失。
JavaScript部分:
createMeteor函数用于创建流星元素,并设置其初始位置和动画持续时间。
setInterval(createMeteor, 500)每隔500毫秒创建一个新的流星元素。
当流星动画结束时,使用animationend事件监听器将其从DOM中移除,以避免内存泄漏。
-->
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>流星雨特效</title>
<style>
body {
margin: 0;
overflow: hidden;
background-color: #000;
}
.meteor {
position: absolute;
width: 2px;
height: 100px;
background: linear-gradient(to bottom, rgba(255, 255, 255, 0), rgba(255, 255, 255, 1));
animation: meteor 1s linear infinite;
}
@keyframes meteor {
0% {
transform: translateY(-100px) rotate(-45deg);
opacity: 1;
}
100% {
transform: translateY(100vh) rotate(-45deg);
opacity: 0;
}
}
</style>
</head>
<body>
<script>
function createMeteor() {
const meteor = document.createElement('div');
meteor.className = 'meteor';
meteor.style.left = Math.random() * window.innerWidth + 'px';
meteor.style.animationDuration = Math.random() * 2 + 5 + 's';
document.body.appendChild(meteor);
meteor.addEventListener('animationend', () => {
document.body.removeChild(meteor);
});
}
setInterval(createMeteor, 500);
</script>
</body>
</html>
(2)方式2:升级版本
【1】先看实现效果
【2】再看实现思路
- CSS部分:
body设置为黑色背景,并隐藏溢出内容。.meteor类定义了流星的样式,使用linear-gradient实现流星的渐变效果。@keyframes meteor定义了流星从左上角移动到右下角的动画,并逐渐消失。 - JavaScript部分:
createMeteor函数用于创建流星元素,并设置其初始位置和动画持续时间。setInterval(createMeteor, 500)每隔500毫秒创建一个新的流星元素。 - 当流星动画结束时,使用animationend事件监听器将其从DOM中移除,以避免内存泄漏。
【3】最后完整代码
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>流星雨特效</title>
<!--
CSS部分:
body设置为黑色背景,并隐藏溢出内容。
.meteor类定义了流星的样式,使用linear-gradient实现流星的渐变效果。
@keyframes meteor定义了流星从左上角移动到右下角的动画,并逐渐消失。
JavaScript部分:
createMeteor函数用于创建流星元素,并设置其初始位置和动画持续时间。
setInterval(createMeteor, 500)每隔500毫秒创建一个新的流星元素。
当流星动画结束时,使用animationend事件监听器将其从DOM中移除,以避免内存泄漏。
-->
<style>
body {
margin: 0;
overflow: hidden;
background-color: #000;
}
.meteor {
position: absolute;
width: 2px;
height: 100px;
background: linear-gradient(to bottom right, rgba(255, 255, 255, 0), rgba(255, 255, 255, 1));
animation: meteor 1s linear infinite;
}
@keyframes meteor {
0% {
/* 左上角 */
transform: translate(0, 0) rotate(-45deg);
opacity: 1;
}
100% {
/* 右下角 */
transform: translate(100vw, 100vh) rotate(-45deg);
opacity: 0;
}
}
</style>
</head>
<body>
<script>
// 控制流星的数量,避免随着时间越来越密集的出现流星
let count = 30;
function createMeteor() {
const meteor = document.createElement('div');
meteor.className = 'meteor';
meteor.style.left = Math.random() * window.innerWidth + 'px';
meteor.style.top = Math.random() * window.innerHeight + 'px';
meteor.style.animationDuration = Math.random() * 2 + 3 + 's';
count = document.body.children.length;
if (count <= 30) {
document.body.appendChild(meteor);
}
meteor.addEventListener('animationend', () => {
document.body.removeChild(meteor);
});
}
setInterval(createMeteor, 500);
</script>
</body>
</html>
(3)方式3:美化版本
【1】先看实现效果
【2】再看实现思路
- CSS部分:
body设置为黑色背景,并隐藏溢出内容。.star类定义了星星的样式,使用border-radius实现圆形,并使用@keyframes twinkle实现星星闪烁的动画。.meteor类定义了流星的样式,使用linear-gradient实现流星的渐变效果。@keyframes meteor定义了流星从左上角移动到右下角的动画,并逐渐消失。 - JavaScript部分:
createStar函数用于创建星星元素,并设置其初始位置和动画持续时间。createMeteor函数用于创建流星元素,并设置其初始位置和动画持续时间。setInterval(createMeteor, 500)每隔500毫秒创建一个新的流星元素。当流星动画结束时,使用animationend事件监听器将其从DOM中移除,以避免内存泄漏。 - 在页面加载时,创建100颗星星。
【3】最后完整源码
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>流星雨与星光闪闪特效</title>
<!--
CSS部分:
body设置为黑色背景,并隐藏溢出内容。
.star类定义了星星的样式,使用border-radius实现圆形,并使用@keyframes twinkle实现星星闪烁的动画。
.meteor类定义了流星的样式,使用linear-gradient实现流星的渐变效果。
@keyframes meteor定义了流星从左上角移动到右下角的动画,并逐渐消失。
JavaScript部分:
createStar函数用于创建星星元素,并设置其初始位置和动画持续时间。
createMeteor函数用于创建流星元素,并设置其初始位置和动画持续时间。
setInterval(createMeteor, 500)每隔500毫秒创建一个新的流星元素。
当流星动画结束时,使用animationend事件监听器将其从DOM中移除,以避免内存泄漏。
在页面加载时,创建100颗星星。
-->
<style>
body {
margin: 0;
overflow: hidden;
background-color: #000;
position: relative;
}
.star {
position: absolute;
width: 2px;
height: 2px;
background-color: #fff;
border-radius: 50%;
animation: twinkle 1s infinite alternate;
}
@keyframes twinkle {
0% {
opacity: 0.5;
}
100% {
opacity: 1;
}
}
.meteor {
position: absolute;
width: 2px;
height: 100px;
background: linear-gradient(to bottom right, rgba(255, 255, 255, 0), rgba(255, 255, 255, 1));
animation: meteor 1s linear infinite;
}
@keyframes meteor {
0% {
transform: translate(0, 0) rotate(-45deg);
opacity: 1;
}
100% {
transform: translate(100vw, 100vh) rotate(-45deg);
opacity: 0;
}
}
</style>
</head>
<body>
<script>
function createStar() {
const star = document.createElement('div');
star.className = 'star';
star.style.left = Math.random() * window.innerWidth + 'px';
star.style.top = Math.random() * window.innerHeight + 'px';
star.style.animationDuration = Math.random() * 2 + 1 + 's';
document.body.appendChild(star);
}
function createMeteor() {
const meteor = document.createElement('div');
meteor.className = 'meteor';
meteor.style.left = Math.random() * window.innerWidth + 'px';
meteor.style.top = Math.random() * window.innerHeight + 'px';
meteor.style.animationDuration = Math.random() * 2 + 1 + 's';
document.body.appendChild(meteor);
meteor.addEventListener('animationend', () => {
document.body.removeChild(meteor);
});
}
// 创建星星
for (let i = 0; i < 100; i++) {
createStar();
}
// 创建流星
setInterval(createMeteor, 500);
</script>
</body>
</html>
如果文章对你有收获,还请不要吝啬【点赞收藏评论】三连哦,你的鼓励将是我成长助力之一!谢谢!
- 上一篇:8个非常实用的Vue自定义指令
- 下一篇:2025微信最流行的头像合集
更多相关网站
- 8个非常实用的Vue自定义指令
- 前端必看!10 个 Vue3 救命技巧,解决你 90% 的开发难题?
- 是时候使用iframe延迟加载来提升LCP!
- 10个Vue开发技巧「实践」
- JavaScript 事件——“事件类型”中“UI事件”的注意要点
- 网络安全与防范
- vue下载excel文件方法
- 前端分享-少年了解过iframe么
- JavaScript代码嵌入HTML的方法、及两者的在执行流程上的细微区别
- 判断变量是否为数组
- JS如何判断文字被ellipsis了?
- ES6页面假死原因及解决方案
- 网络安全之从原理看懂XSS
- VUE前端编程:如何通过全局对话框引入动态组件
- 一文讲透支付宝沙箱的基本应用
- Js基础3:节点创建
- 32个手写JS,巩固你的JS基础(面试高频)
- Chrome 扩展开发:哪种实现方式适合您的需求
- 最近发表
-
- 联想推出 IdeaPad 14s / 15s:均为 3399 元,运行 Win11 系统
- 顶配版ThinkPad X1 Carbon评测
- 联想ThinkPad X1 Carbon评测
- lenovo联想 拯救者-14 加装ssd、内存及win10转移到ssd经验谈
- 联想发布新款耳机鼠标等配件:专为ThinkPad X1设计
- 杜比全景音体验,联想K4 Note在印度正式发布
- 3099 元起,联想推出 IdeaPad 15:约10小时续航,预装 Win11系统
- 联想拯救者Y70、小新Pad Pro 2022发布丨拯救者Y70测评体验
- 千元可定制!联想K4 Note印度发布:杜比全景音体验
- 声临其境 联想TAB2 A10平板联手杜比
- 标签列表
-
- serv-u 破解版 (6)
- 极域电子教室2009 (6)
- 6300主题下载 (1)
- oracle11204下载 (1)
- c++论坛 (14)
- huaweiupdateextractor (4)
- thinkphp6下载 (7)
- 前端论坛 (11)
- mysql 时间索引 (13)
- mydisktest_v298 (35)
- unlocker208 (1)
- sql 日期比较 (33)
- document.appendchild (35)
- 头像打包下载 (35)
- 二调符号库 (23)
- oppoa5专用解锁工具包 (8)
- acmecadconverter_8.52绿色版 (25)
- oracle timestamp比较大小 (7)
- chm editor破解版 (7)
- throttlestop防止降频 (9)
- f12019破解 (16)
- 流星蝴蝶剑修改器 (18)
- pygame中文手册 (2)
- 联想杜比音效驱动下载 (10)