0

0

css动画如何实现弹性效果_css动画缓动曲线用法

P粉602998670

P粉602998670

发布时间:2026-01-27 14:04:00

|

694人浏览过

|

来源于php中文网

原创

用cubic-bezier(0.68,-0.55,0.27,1.55)可实现可控弹性动画,其负y1值制造初始下拉,超1的y2值产生回弹,配合单次scale关键帧与0.4s–0.8s时长达成自然效果。

css动画如何实现弹性效果_css动画缓动曲线用法

cubic-bezier() 实现弹性效果的关键参数

纯 CSS 实现弹性(bounce)动画,核心不是靠多层关键帧,而是用自定义的 cubic-bezier() 缓动函数模拟物理回弹。浏览器原生的 ease-in-outspring()(实验性)都不够精准;真正可控、复用性强的方式是手写贝塞尔值。

典型弹性曲线需满足:初始加速快 → 超调(overshoot)→ 多次衰减回弹 → 最终静止。推荐起手参数:cubic-bezier(0.68, -0.55, 0.27, 1.55) —— 这组值在多数尺寸和时长下能稳定出弹性感,负的 y1 和大于 1 的 y2 是实现“拉伸后反弹”的必要条件。

  • 第一对控制点 (x1, y1)y1 让动画起始阶段“向下猛拉”(视觉上像压弹簧)
  • 第二对 (x2, y2)y2 > 1 使动画末段冲过目标位置再折返,形成回弹
  • 避免 x1 > x2(如 cubic-bezier(0.8, 0, 0.2, 1)),这会导致时间轴倒流,动画卡顿或跳变

@keyframes 配合 cubic-bezier() 的最小可行写法

不要试图在 @keyframes 里用多个 transform: scale() 关键帧模拟弹性——那会显得生硬且难调。正确做法是:只设起始和结束状态,把“弹性感”全交给 animation-timing-function

button {
  animation: pulse 0.6s cubic-bezier(0.68, -0.55, 0.27, 1.55);
}
@keyframes pulse {
  from { transform: scale(1); }
  to { transform: scale(1.15); }
}

注意:animation-duration 建议控制在 0.4s–0.8s。太短(如 0.2s)会让回弹来不及展开;太长(如 1.2s)则失去“弹性”的瞬时反馈感。若需多次弹跳,应叠加多个独立动画,而非延长单次 duration。

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

MOKI
MOKI

MOKI是美图推出的一款AI短片创作工具,旨在通过AI技术自动生成分镜图并转为视频素材。

下载

为什么 spring() 不建议在生产环境直接用

spring(mass, stiffness, damping, initialVelocity) 是 Chrome 125+ 和 Safari 17.4+ 支持的实验性函数,写起来确实直观,比如 spring(1, 200, 20, 0)。但它有三个硬伤:

  • Firefox 全系不支持,且无明确落地时间表
  • 参数含义与物理公式强耦合,mass=1 并不等于“轻”,实际表现受元素尺寸、父容器渲染上下文影响极大
  • 当动画被 JavaScript 中断(如用户快速连续点击)、或触发 will-change 切换时,容易出现回弹中断、残留位移等不可预测行为

除非项目明确限定 Chromium 内核 + 可接受降级为 ease-out,否则优先选 cubic-bezier()

调试弹性曲线的实用技巧

别靠猜。打开 Chrome DevTools → Elements → Styles → 找到 animation-timing-function → 点击右侧贝塞尔图标,拖动控制点实时预览。重点关注两个现象:

  • 曲线是否穿过 (0,0) 和 (1,1)?没穿过说明动画不会从 0% 开始、也不会停在 100%,会偏移
  • 曲线是否在 y=1 上方有明显凸起?这是回弹的视觉来源;如果只有轻微上翘,弹性会弱得几乎察觉不到
  • 导出调试好的值后,用 calc() 封装可维护变量:--elastic: cubic-bezier(0.68, -0.55, 0.27, 1.55); animation-timing-function: var(--elastic);

真正难的不是写出第一个弹性动画,而是让同一套曲线在按钮、卡片、加载指示器上都保持协调的“重量感”。这意味着你得为不同组件微调 y1/y2 —— 比如小图标适合更激进的 y1: -0.7,而模态框入场可能需要压低 y2: 1.3 避免晃动感过强。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

112

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

26

2026.01.26

chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

826

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

743

2023.11.06

function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

482

2023.08.04

js函数function用法
js函数function用法

js函数function用法有:1、声明函数;2、调用函数;3、函数参数;4、函数返回值;5、匿名函数;6、函数作为参数;7、函数作用域;8、递归函数。本专题提供js函数function用法的相关文章内容,大家可以免费阅读。

163

2023.10.07

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

109

2026.01.26

edge浏览器怎样设置主页 edge浏览器自定义设置教程
edge浏览器怎样设置主页 edge浏览器自定义设置教程

在Edge浏览器中设置主页,请依次点击右上角“...”图标 > 设置 > 开始、主页和新建标签页。在“Microsoft Edge 启动时”选择“打开以下页面”,点击“添加新页面”并输入网址。若要使用主页按钮,需在“外观”设置中开启“显示主页按钮”并设定网址。

16

2026.01.26

热门下载

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

精品课程

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

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

CSS教程
CSS教程

共754课时 | 24.3万人学习

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

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