【css技巧】用 CSS 实现:移入立即执行,移出延时返回

🎯 用 CSS 实现:移入立即执行,移出延时返回

一、目标

实现一个常见交互:

  • hover 进入:立即展开
  • hover 离开:延迟一段时间再收回

二、为什么直觉写法会失败

很多人会这样写:

html 复制代码
<button
  class="transition-all duration-300
         delay-1000 hover:delay-0
         hover:right-1"
>

结果:

❌ 进入也被延迟

原因一句话:

delay 在动画触发时就被确定,hover 时来不及生效


三、CSS 可行解法(核心思路)

只让"离开时"带 delay,而"进入时"没有 delay

但 CSS 没有"进入 / 离开"状态区分能力,所以需要绕开:

👉 让 delay 不参与动画触发过程


四、实现方案(推荐)

html 复制代码
<button
  class="fixed -right-[80px]
         transition-[right]
         duration-300
         delay-1000
         hover:right-1
         hover:delay-0"
>

五、为什么这个能成立

关键点:

1️⃣ 限制 transition 属性

css 复制代码
transition-property: right;

意味着:

  • 只有 right 会触发动画
  • delay 只是参数,不参与"变化竞争"

2️⃣ 两个阶段的行为

✔ hover 进入
  • right 变化 → 触发动画
  • 此时 delay = 0
  • 👉 立即执行

✔ hover 离开
  • right 变化 → 再次触发动画
  • 此时 delay = 1000ms
  • 👉 延迟 1 秒后收回

六、效果本质

你实现的其实是:

同一个动画,不同触发方向使用不同 delay


七、工程建议

❌ 避免

css 复制代码
transition-all

问题:

  • 所有属性参与 transition
  • delay 容易失效或行为不确定

✅ 推荐写法

css 复制代码
transition-[具体属性]

优点:

  • 行为稳定
  • 易于推导
  • 无隐式副作用

八、扩展(适用场景)

这种写法适用于:

  • 悬浮按钮(AI / 客服入口)
  • 侧边工具栏
  • hover 展开的操作面板

本质都是:

防误触:快速响应进入,延迟响应离开


九、一句话总结

要实现"进快出慢",关键不是控制 hover,而是控制"触发动画时的 delay"

相关推荐
神奇的程序员17 小时前
我的软件冲进苹果商店下载榜前 50 了
前端
阳光是sunny18 小时前
别再被 worktree 绕晕了!AI 编程时代你必须掌握的 Git 隔离神器
前端·人工智能·后端
万少19 小时前
万少的博客 - 技术分享与解决方案
前端·javascript·后端
尘世中一位迷途小书童21 小时前
用 Cesium 撸了一个森林火情监控大屏,弧线、粒子、发光效果都齐了
前端·javascript
IT_陈寒1 天前
垃圾回收器选错了,我的Java服务内存炸了
前端·人工智能·后端
月光下的丝瓜1 天前
Flutter 国内安装指南
前端·flutter
玄星啊1 天前
AI 编程的第 30 天,我怀念古法 Coding 了
前端·ai编程
Jolyne_1 天前
Angular基础速通
前端·angular.js
锋行天下1 天前
半秒开!还有谁!!!
前端·vue.js·架构
代码搬运媛1 天前
git 下中文文件名乱码问题解决
前端