
本文将介绍如何使用 CSS 实现一个简单的月亮升起和落下的动画效果。通过关键帧动画和 CSS 属性,我们可以模拟月亮从左上角升起,然后从右上角落下的过程。本文将提供详细的代码示例和解释,帮助你理解动画的实现原理,并解决动画结束后月亮仍然可见的问题。
这个动画的核心是使用 CSS 的 @keyframes 规则来定义动画的关键帧,并通过 animation 属性将动画应用到月亮图片上。
关键帧动画 (@keyframes): 定义了动画的起始状态 (from) 和结束状态 (to)。在这个例子中,我们改变了 left 属性的值,使月亮从屏幕左侧移动到右侧。
动画属性 (animation): 用于控制动画的播放方式,包括动画名称、持续时间、时间函数、迭代次数、方向和填充模式等。
立即学习“前端免费学习笔记(深入)”;
以下是完整的 HTML 和 CSS 代码,用于实现月亮升起和落下的动画效果:
HTML (index.html):
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Animated Moon</title>
<link rel="stylesheet" href="style.css">
</head>
<body>
<header>
<img src="https://i.sstatic.net/M1OFe.png" alt="Moon">
</header>
</body>
</html>CSS (style.css):
*{
box-sizing: border-box;
}
body {
background-image: url("https://i.sstatic.net/ZO2wI.jpg");
background-repeat: no-repeat;
background-size: cover;
overflow-x: hidden; /* 隐藏水平滚动条 */
}
img{
width: 150px;
height: 200px;
position: relative;
border-radius: 50%;
animation-name: move;
animation-duration: 2s;
animation-timing-function: ease-in-out;
animation-iteration-count: 1;
animation-direction: normal;
animation-fill-mode: both;
transform: translateX(250)
}
@keyframes move{
from{left:-250px; }
to{left: 110%;} /* 确保完全移出屏幕 */
}box-sizing: border-box;: 保证元素的总宽度和高度包括内边距和边框。
body 样式:
img 样式:
@keyframes move:
通过使用 CSS 关键帧动画和 overflow-x: hidden; 属性,我们可以轻松实现一个简单的月亮升起和落下的动画效果。希望本文能够帮助你理解 CSS 动画的实现原理,并在你的项目中应用这些技巧。
以上就是CSS 实现月亮升起与落下的动画效果的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号