0

0

CSS如何实现具有重力感的下坠动效_利用cubic-bezier模拟物理加速度css

P粉602998670

P粉602998670

发布时间:2026-03-11 16:28:03

|

852人浏览过

|

来源于php中文网

原创

关键参数是cubic-bezier(0.34, 1.56, 0.64, 1),其中y1=1.56控制起始快速加速,y2=1压平末端模拟缓冲;需配合translatey(px)、微回弹关键帧及will-change优化。

css如何实现具有重力感的下坠动效_利用cubic-bezier模拟物理加速度css

cubic-bezier 模拟重力下坠的关键参数怎么选

纯 CSS 实现“有重量感”的下坠,核心不是加动画时长,而是让 transition-timing-function@keyframes 中的 cubic-bezier 曲线逼近真实自由落体的加速度衰减过程——起始慢、中间快、末端急停但带一点回弹余量。

常见错误是直接套用 cubic-bezier(0.25, 0.46, 0.45, 0.94)(MDN 推荐的“ease-in-out”),它太对称,没有下坠的“沉”感;或者用 ease-in,又太生硬、像断电坠落。

  • 真正可用的起点是 cubic-bezier(0.34, 1.56, 0.64, 1):前两个值拉高起始斜率(模拟初速为0后快速加速),后两个值压平末端(模拟空气阻力+接触缓冲)
  • 如果需要更“重”,把第二项(y1)提到 1.7 甚至 1.9,但超过 2.0 会导致视觉跳变(曲线超出 [0,1] 范围,CSS 会 clamp,反而失真)
  • 千万别用 y1 > y2 且差值过大(比如 cubic-bezier(0.1, 2.0, 0.9, 0.1)),浏览器渲染会抖动,尤其在 Safari 上

transform translateY 配合 cubic-bezier 的实际写法

只靠 topmargin-top 位移会触发重排,卡顿明显;必须用 transform: translateY() 才能走合成层,保证 60fps。

典型场景:点击按钮后,一个卡片从当前位置“砸”到下方 80px 处并微微回弹。

星月写作
星月写作

专为网络小说、 剧本创作者打造的AI增效工具

下载

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

  • transition:给元素加 transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);,再通过 JS 切换 class 添加 transform: translateY(80px);
  • @keyframes 更可控:定义 @keyframes drop { 0% { transform: translateY(0); } 70% { transform: translateY(85px); } 100% { transform: translateY(80px); } },然后在 animation-timing-function 里配同款 cubic-bezier
  • 注意:translateY 值别写成百分比(如 100%),父容器高度变化时行为不可控;固定 px/rem 更稳

为什么加一点点回弹比完全停住更“有重力感”

真实物体落地不会戛然而止,总会因弹性形变产生微小反弹。CSS 里模拟这个,不是靠 JS 物理引擎,而是靠 timing function 的末端“过冲”+ 关键帧微调。

错误做法:用两个连续 animation(先下坠再回弹),时间衔接难,容易露马脚。

  • 推荐做法:在关键帧 90% 处让位移略超目标值(比如目标 80px,90% 到 83px),100% 回到 80px,配合 cubic-bezier 让后段减速变缓,自然形成“压一下再稳住”的错觉
  • 如果想强化反馈,可在 95% 插入 transform: scaleY(0.98),模拟触地瞬间轻微压缩,立刻恢复 —— 这比纯位移更有物理感
  • 慎用 scaleY 动画配大数值(如 scaleY(0.8)),文字会糊,且在低分辨率屏上边缘锯齿明显

移动端和 Safari 的兼容性陷阱

cubic-bezier 在所有现代浏览器都支持,但 Safari 对超出 [0,1] 范围的 y 值(比如 y1=1.7)渲染不稳定:有时正常,有时首帧卡在起点不动,有时动画直接跳过。

  • 实测安全上限:Safari 15+ 可稳定用到 y1=1.65,iOS 14 及更早建议 ≤ 1.5
  • 绕过方案:不用超限 y1,改用两段动画——先 cubic-bezier(0.22, 0.61, 0.36, 1) 快速下坠 90%,再接一段 cubic-bezier(0.42, 0, 0.58, 1) 缓冲最后 10%
  • 别忘了加 will-change: transform;,尤其在 iOS 上,否则首次动画可能闪一下
重力感不来自参数多复杂,而在于加速度变化是否符合人眼对“质量存在”的直觉判断。最容易被忽略的是:落地瞬间的微压缩和末端 5% 时间里的速度衰减节奏——这两处差一点,整个动效就变“轻飘”。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

870

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

30

2025.12.06

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

530

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

576

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

6176

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

492

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 41.9万人学习

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

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