0

0

CSS如何制作一个无限流动的波浪背景_通过多层伪元素位移动画css

P粉602998670

P粉602998670

发布时间:2026-03-09 13:46:05

|

265人浏览过

|

来源于php中文网

原创

真正稳的波浪动画需叠两层 radial-gradient:一层慢速大波、一层快速小波,background-position 以不同速率移动且周期互质(如8s和12s),配合 background-size 差异、位移值略大于宽度、transform 替代 background-position、overflow: hidden 和 z-index 控制,可避免断点、掉帧与层级问题。

css如何制作一个无限流动的波浪背景_通过多层伪元素位移动画css

::before::after 叠两层 radial-gradient 波浪就够了

单靠一个伪元素做“无限流动波浪”会露馅——边缘衔接生硬、速度难调、移动端掉帧。真正稳的方案是叠两层:一层慢速大波,一层快速小波,错开位移周期,视觉上就糊不出断点。

关键不是画多逼真的波形,而是让两层 background-position 以不同速率水平移动,且周期互质(比如 8s 和 12s),自然形成不重复的流动感。

  • 别用 linear-gradient 拼波浪线——锯齿明显,缩放失真
  • radial-gradient(circle at 50% -50%, transparent 40%, #4a90e2 40%) 这类写法能搓出平滑弧顶,再配合 background-size: 200% 200% 控制波长
  • 两层伪元素的 animation-duration 必须不同,差值建议 ≥3s,否则容易看出同步抖动

动画卡顿?检查 will-changetransform 替代方案

直接 animating background-position 在低端安卓或 Safari 上大概率掉帧,尤其页面有滚动时。更稳妥的做法是把波浪图层抽成独立 div,用 transform: translateX() 驱动,再加 will-change: transform 提前告知浏览器要动它。

  • 如果坚持用伪元素,必须给父容器设 overflow: hidden,否则位移过程会溢出显示撕裂
  • transform 动画比 background-position 节省 GPU 资源,但要注意:伪元素无法直接触发硬件加速,得套一层 div 包裹再动
  • Safari 对 radial-gradient + animation 组合有渲染 bug,加 -webkit-mask-image 做遮罩可绕过

@keyframes 里写 100% 位移值不能等于 background-size

常见错误是设 background-size: 400px 200px,然后 @keyframes wave { 0% { background-position: 0 0; } 100% { background-position: 400px 0; } }——这样动画结束瞬间会跳回起点,产生卡顿感。

ChatTTS
ChatTTS

ChatTTS是一个开源的TTS文本转语音生成模型,专为对话场景设计。

下载

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

  • 正确做法是让位移值略大于 background-size 的宽度,比如 background-size: 400px 200px,则 100% 设为 420px,利用浏览器插值平滑过渡
  • 两层动画的 background-size 宽度最好不同(如 380px / 450px),避免波峰波谷长期重合变“静止”
  • 别用 % 单位写位移,background-position: 100% 0 在不同 background-size 下行为不一致,统一用 px

移动端适配:用 vh 控制高度,但禁用 background-attachment: fixed

波浪背景常用于全屏 Banner,用 height: 100vh 最直接。但 iOS Safari 里 background-attachment: fixed 会导致波浪错位甚至消失,必须关掉。

  • 改用绝对定位的子容器撑高,父容器设 position: relative,子容器 position: absolute; top: 0; left: 0; width: 100%; height: 100vh;
  • 伪元素的 top/bottom/left/right 要设具体值(如 top: 0; bottom: 0;),别依赖 height: 100%,后者在 flex 容器里可能失效
  • Android WebView 对 radial-gradient 渲染精度低,加 background-repeat: repeat-x 并调大 background-size 宽度能缓解锯齿

最麻烦的其实是波浪和内容文字的层级关系——伪元素默认 z-index 低于内容,但一旦加了 transform 就会创建新层叠上下文,这时候得手动调 z-index,不然文字会被盖住。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
CSS position定位有几种方式
CSS position定位有几种方式

有4种,分别是静态定位、相对定位、绝对定位和固定定位。更多关于CSS position定位有几种方式的内容,可以访问下面的文章。

83

2023.11.23

overflow什么意思
overflow什么意思

overflow是一个用于控制元素溢出内容的属性,当元素的内容超出其指定的尺寸时,overflow属性可以决定如何处理这些溢出的内容。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1853

2024.08.15

flex教程
flex教程

php中文网为大家带来了flex教程合集,Flex是采用Flex布局的元素,称为Flex容器(flex container),简称"容器",它的所有子元素自动成为容器成员,有三个核心概念: flex项,需要布局的元素;flex容器,其包含flex项;排列方向,这决定了flex项的布局方向。php中文网还为大家带来flex的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

369

2023.06.14

android开发三大框架
android开发三大框架

android开发三大框架是XUtil框架、volley框架、ImageLoader框架。本专题为大家提供android开发三大框架相关的各种文章、以及下载和课程。

337

2023.08.14

android是什么系统
android是什么系统

Android是一种功能强大、灵活可定制、应用丰富、多任务处理能力强、兼容性好、网络连接能力强的操作系统。本专题为大家提供android相关的文章、下载、课程内容,供大家免费下载体验。

1819

2023.08.22

android权限限制怎么解开
android权限限制怎么解开

android权限限制可以使用Root权限、第三方权限管理应用程序、ADB命令和Xposed框架解开。详细介绍:1、Root权限,通过获取Root权限,用户可以解锁所有权限,并对系统进行自定义和修改;2、第三方权限管理应用程序,用户可以轻松地控制和管理应用程序的权限;3、ADB命令,用户可以在设备上执行各种操作,包括解锁权限;4、Xposed框架,用户可以在不修改系统文件的情况下修改应用程序的行为和权限。

2128

2023.09.19

android重启应用的方法有哪些
android重启应用的方法有哪些

android重启应用有通过Intent、PendingIntent、系统服务、Runtime等方法。本专题为大家提供Android相关的文章、下载、课程内容,供大家免费下载体验。

284

2023.10.18

Android语音播放功能实现方法
Android语音播放功能实现方法

实现方法有使用MediaPlayer实现、使用SoundPool实现两种。可以根据具体的需求选择适合的方法进行实现。想了解更多语音播放的相关内容,可以阅读本专题下面的文章。

379

2024.03.01

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

59

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

CSS教程
CSS教程

共754课时 | 41.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号