CSS 实现月亮升起与降落动画效果

css 实现月亮升起与降落动画效果

本文将介绍如何使用 CSS 关键帧动画实现月亮从左上角升起,最终在右上角落下的动画效果。通过设置 overflow-x: hidden 属性,可以有效隐藏超出屏幕范围的元素,避免出现滚动条。同时,微调动画结束位置,确保月亮完全消失在视野之外,从而实现更加自然的动画效果。

动画原理

该动画的核心在于 CSS 关键帧 (@keyframes),它定义了动画在不同时间点的状态。 通过 left 属性的改变,控制月亮在水平方向上的移动,模拟升起和降落的效果。

代码实现

以下是实现该动画效果的 CSS 代码:

*{    box-sizing: border-box;}@keyframes move {    from {        left: -250px;    }    to {        left: 110%; /* 确保月亮完全移出屏幕 */    }}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);}

以下是HTML代码:

立即学习“前端免费学习笔记(深入)”;

            Animated Moon        
@@##@@

代码解释:

@keyframes move: 定义名为 move 的关键帧动画。

from { left: -250px; }: 动画起始时,月亮位于屏幕左侧之外 -250px 的位置。to { left: 110%; }: 动画结束时,月亮移动到屏幕右侧之外 110% 的位置。 110% 确保月亮完全移出屏幕,避免出现滚动条。

body:

background-image: 设置背景图片。background-repeat: 禁止背景图片重复。background-size: 使背景图片覆盖整个屏幕。overflow-x: hidden;: 关键属性,隐藏水平方向上超出 body 元素的任何内容,防止出现滚动条。

img:

width 和 height: 设置月亮图片的宽高。position: relative: 允许使用 left 属性进行定位。border-radius: 50%: 使月亮图片呈现圆形。animation-name: move: 应用名为 move 的动画。animation-duration: 2s: 动画持续时间为 2 秒。animation-timing-function: ease-in-out: 动画的缓动函数,使动画开始和结束时速度较慢,中间速度较快。animation-iteration-count: 1: 动画播放一次。animation-direction: normal: 动画正向播放。animation-fill-mode: both: 动画结束后,保持 to 状态的样式。transform: translateX(250): 初始位置向右偏移250px,确保在动画开始前,月亮在起始位置。

注意事项

图片资源: 确保提供的图片链接有效,并且图片尺寸适合。overflow-x: hidden 的影响: 虽然 overflow-x: hidden 可以解决滚动条问题,但它会隐藏任何水平方向上超出 body 元素的其他内容。 因此,在应用此属性时,需要确保不会影响其他元素的正常显示。动画参数调整: 可以根据需要调整动画的 duration、timing-function 和 left 的起始和结束值,以获得最佳的动画效果。兼容性: 该方法具有良好的浏览器兼容性,可以在主流浏览器上正常运行。

总结

通过使用 CSS 关键帧动画和 overflow-x: hidden 属性,可以轻松实现月亮升起和降落的动画效果。 该方法简单易懂,并且具有良好的可定制性,可以根据实际需求进行调整。在实际开发中,可以根据需要添加更多的动画效果,例如改变月亮的大小、颜色等,以增强动画的视觉效果。

Moon

以上就是CSS 实现月亮升起与降落动画效果的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1572909.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月22日 15:00:15
下一篇 2025年12月22日 15:00:31

相关推荐

  • 表单中的颜色选择器怎么自定义?如何集成第三方插件?

    答案:自定义表单颜色选择器需超越原生input[type=”color”]的限制,通过引入Coloris等第三方插件实现透明度支持、多格式转换和统一UI。原生方案样式控制有限且兼容性差,仅能调整基本外观;而使用JavaScript插件可高度定制,提升体验与开发效率。集成步骤包…

    2025年12月22日
    000
  • HTML如何设置文本下划线?u标签的用法是什么?

    最推荐使用CSS的text-decoration属性为HTML文本添加下划线,因为它遵循结构与样式分离的原则,提供更强的语义化、灵活性和可维护性,而标签仅应在表示非文本注释(如拼写错误)时考虑使用,且CSS还支持overline、line-through等其他文本装饰及颜色、样式、粗细等精细化控制,…

    2025年12月22日
    000
  • HTML表单如何实现自动化测试?怎样用Selenium测试表单?

    答案:自动化测试HTML表单需应对动态元素、客户端验证、异步提交和验证码等挑战,采用显式等待、稳定定位策略、测试环境绕行验证码;通过Page Object Model提升可维护性,结合数据驱动测试覆盖多场景,利用显式断言、截图辅助调试,并深入验证客户端与服务器端验证、表单状态变化、文件上传、AJAX…

    2025年12月22日
    000
  • HTML如何设置表单时间选择?input type=”time”的作用是什么?

    最直接的方式是使用 input type=”time”,它提供原生时间选择器,支持 min、max、step 等属性限制范围和步长,可通过 value 设置默认值,JavaScript 可通过 value 属性获取或设置时间,格式为 “HH:MM”,并…

    2025年12月22日
    000
  • 深入理解JavaScript原生Alert的样式限制及自定义模态框实现

    本文深入探讨了JavaScript原生alert弹窗的样式修改限制,指出其无法直接通过代码进行定制。文章详细阐述了为何原生alert不支持HTML或CSS样式,并提供了创建自定义模态对话框作为替代方案的指导,以实现对弹窗内容、颜色和字体等元素的完全控制,从而提升用户体验和界面一致性。 原生Alert…

    2025年12月22日
    000
  • HTML表单如何实现扫码功能?怎样调用摄像头扫描二维码?

    答案:HTML表单通过JavaScript调用摄像头并利用jsQR等库解析二维码,将结果自动填充至输入框。实现步骤包括:使用getUserMedia获取摄像头权限,在中显示画面,通过捕获帧数据,用jsQR分析图像中的二维码,识别后停止视频流并填入结果。需注意HTTPS协议、用户隐私、浏览器兼容性(如…

    2025年12月22日
    000
  • HTML如何实现无限滚动?滚动加载更多怎么做?

    无限滚动是现代网页设计的常见选择,因为它提供无缝浏览体验,减少用户操作成本,提升内容发现率和停留时间,尤其适用于社交媒体、新闻和图片类应用;2. 实现时常见挑战包括滚动事件频繁触发导致性能问题,需通过节流或防抖优化,大量dom节点引发内存占用过高,应采用虚拟列表技术缓解,还需处理加载状态、错误提示及…

    2025年12月22日
    000
  • HTML表单如何添加提交按钮?submit按钮和其他按钮有什么区别?

    答案:HTML表单中添加提交按钮主要使用或,前者简单但内容受限,后者支持丰富内容和更好样式控制,现代开发更推荐后者;此外还有type=”button”用于自定义功能和type=”reset”用于重置表单,JavaScript可通过preventDefa…

    2025年12月22日
    000
  • caption标签的用途是什么?表格标题怎么添加?

    表格需要标题是因为它能明确传达表格主题,提升用户体验和seo;2. 使用 标签可为屏幕阅读器用户提供语义化上下文,帮助其理解表格内容;3. 搜索引擎通过 更好地解析表格主题,增强页面相关性并可能在搜索结果中展示标题;4. 必须作为 的第一个子元素,置于 等标签之前以符合规范;5. 可通过css自定义…

    2025年12月22日 好文分享
    000
  • HTML如何制作下拉导航?CSS如何控制菜单显示?

    制作下拉导航菜单的核心思路是1.用html嵌套无序列表搭建结构,2.用css通过position:relative和position:absolute配合实现子菜单定位,3.利用:hover触发display、opacity、visibility或transform等属性变化来控制子菜单显隐;为提升…

    2025年12月22日
    000
  • HTML表单如何实现表情选择?怎样添加表情符号插件?

    答案:通过引入表情符号库、构建选择器界面、监听点击事件及处理提交数据实现HTML表单表情选择。使用CSS自定义样式,通过JavaScript检测浏览器支持并用图片替换实现旧浏览器兼容,采用懒加载、虚拟列表、分页、搜索和缓存优化性能。 HTML表单实现表情选择,核心在于提供一个用户友好的表情选择界面,…

    2025年12月22日
    000
  • 表单中的输入事件怎么处理?input和change事件有什么区别?

    答案:input事件在值变化时立即触发,change事件在失去焦点且值改变后触发,二者适用于不同场景。 表单中的输入事件处理,核心在于监听用户的输入行为,并做出相应的响应。 input 和 change 事件是两个关键的事件类型,但它们触发的时机和使用场景有所不同。理解它们的区别,能更精准地控制表单…

    2025年12月22日
    000
  • HTML如何设置文本斜体?i和em标签的区别是什么?

    使用标签仅实现斜体样式,无语义强调,适用于书名、外来语等;使用标签表示语义强调,影响SEO和可访问性,适合突出重要内容。 HTML中,你可以用 标签或者 标签来让文本显示为斜体。但它们背后的含义却不太一样。 解决方案: 使用 标签: 标签是 “italic” 的缩写,它仅仅是…

    2025年12月22日
    000
  • JavaScript 获取多个 标签的 href 值

    本文旨在提供一种高效且简洁的方法,利用 JavaScript 获取页面中多个 标签的 href 属性值,并在用户点击链接时,通过弹窗显示目标 URL,最终实现页面跳转。我们将探讨如何使用事件委托技术,避免为每个链接单独绑定事件监听器,从而提高代码的可维护性和性能。 使用事件委托处理多个链接点击事件 …

    2025年12月22日
    000
  • HTML表单如何实现风险评分?怎样评估提交的可信度?

    HTML表单风险评分旨在评估用户提交数据的可信度,通过一系列指标来判断是否存在欺诈或恶意行为的可能性。这并非一个简单的“是”或“否”的判断,而是一个概率评估。 评估HTML表单提交风险涉及多方面因素,以下是一些关键策略和实现方法。 用户行为分析 IP地址信誉 IP地址是用户访问网络的入口,通过分析I…

    2025年12月22日
    000
  • 什么是HTML格式?如何运行HTML文件?

    运行html文件最简单的方法是双击文件或拖入浏览器,但涉及动态内容时应使用本地服务器;2. python、vs code的live server或node.js的http-server均可快速搭建本地服务器;3. html定义网页结构,css负责样式,javascript实现交互,三者协同构成前端开…

    2025年12月22日 好文分享
    000
  • 为滚动动画元素添加延迟效果

    本文旨在解决在网页滚动时,同一行的元素同时出现动画效果的问题。通过JavaScript代码,为每个元素添加基于其索引的延迟,从而实现元素依次出现的动画效果,提升用户体验。本文将提供修改后的代码示例,并解释其实现原理和注意事项。 实现原理 核心思路是在原有的滚动监听和元素显示逻辑的基础上,引入setT…

    2025年12月22日
    000
  • 使用 loading=”lazy” 在 iOS 移动浏览器上导致崩溃的解决方案

    本文探讨了在 Webflow 网站中使用 loading=”lazy” 属性加载图片时,在 iOS 移动浏览器(Safari)上出现崩溃或无限重载的问题。通过分析原因和提供解决方案,帮助开发者避免此类问题,并确保网站在不同平台上的稳定性和用户体验。针对 Safari 浏览器对…

    2025年12月22日
    000
  • HTML表单如何实现横竖屏适配?怎样调整布局方向?

    答案:利用CSS媒体查询结合Flexbox或Grid布局,通过视口元标签、移动优先设计及容器查询等技术,实现表单在横竖屏下的自适应布局与输入体验优化。 HTML表单在横竖屏下的适配,核心思路在于利用CSS的媒体查询(Media Queries)来检测设备的屏幕方向,然后根据不同的方向应用不同的布局样…

    2025年12月22日
    000
  • JavaScript 实现元素滚动动画延迟效果

    本文介绍了如何使用 JavaScript 为滚动动画中的元素添加延迟效果,解决同排元素同时出现的问题,提升用户体验。通过修改 JavaScript 代码,利用 setTimeout 函数,根据元素在容器中的索引设置不同的延迟时间,从而实现元素依次显示的动画效果。 为滚动动画添加元素延迟显示 在网页设…

    2025年12月22日
    000

发表回复

登录后才能评论
关注微信