返回顶部
A

Animations

Create performant web animations with proper accessibility and timing.

作者: admin | 来源: ClawHub
源自
ClawHub
版本
V 1.0.0
安全检测
已通过
1,507
下载量
2
收藏
概述
安装方式
版本历史

Animations

## GPU-Accelerated Properties Only these properties animate on the compositor thread (60fps): | Property | Use | |----------|-----| | `transform` | Move, rotate, scale (translateX, rotate, scale) | | `opacity` | Fade in/out | Everything else triggers layout or paint. Avoid animating: - `width`, `height`, `margin`, `padding` (layout thrashing) - `top`, `left`, `right`, `bottom` (use transform instead) - `border-width`, `font-size` (expensive reflows) ```css /* ❌ Triggers layout every frame */ .slide { left: 100px; transition: left 0.3s; } /* ✅ GPU accelerated */ .slide { transform: translateX(100px); transition: transform 0.3s; } ``` ## Reduced Motion ~5% of users experience vestibular disorders (dizziness, nausea from motion). ```css /* Only animate if user hasn't requested reduced motion */ @media (prefers-reduced-motion: no-preference) { .animated { animation: slide-in 0.5s ease-out; } } /* Or disable for those who requested it */ @media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; } } ``` Keep subtle fades and color changes even with reduced motion. Remove parallax, bouncing, infinite loops. ## Timing Functions | Easing | Use case | |--------|----------| | `ease-out` | Elements entering view (appears responsive) | | `ease-in` | Elements exiting view (accelerates away) | | `ease-in-out` | Elements moving within view | | `linear` | Only for spinners, progress bars, color cycling | ```css /* Custom bounce */ transition: transform 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55); /* Material Design standard */ transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1); ``` ## Duration Guidelines | Type | Duration | |------|----------| | Micro-interactions (hover, focus) | 100-200ms | | Transitions (modals, dropdowns) | 200-300ms | | Page transitions | 300-500ms | | Complex choreography | 500-1000ms max | Anything over 500ms feels sluggish. Shorter is usually better. ## CSS Transitions vs Animations **Transitions:** A to B state changes ```css .button { transform: scale(1); transition: transform 0.2s ease-out; } .button:hover { transform: scale(1.05); } ``` **Animations:** Multi-step, auto-play, looping ```css @keyframes fadeSlideIn { 0% { opacity: 0; transform: translateY(20px); } 100% { opacity: 1; transform: translateY(0); } } .card { animation: fadeSlideIn 0.5s ease-out forwards; } ``` Use transitions for hover/focus states. Use animations for on-load effects and sequences. ## will-change Only use as optimization when you have specific performance problems: ```css /* ✅ Apply before animation starts, remove after */ .card:hover { will-change: transform; } .card { will-change: auto; } /* ❌ Never apply globally */ * { will-change: transform, opacity; } /* Wastes GPU memory */ ``` ## Transition Property Specificity ```css /* ❌ Animates everything including unintended properties */ .card { transition: all 0.3s; } /* ✅ Only animates what you need */ .card { transition: transform 0.3s, box-shadow 0.3s; } ``` `all` can cause unexpected animations on color, background, border changes. ## React/Framework Traps **Exit animations require AnimatePresence:** ```jsx /* ❌ Exit animation never plays */ {isVisible && <motion.div exit={{ opacity: 0 }} />} /* ✅ Wrap conditional rendering */ <AnimatePresence> {isVisible && <motion.div exit={{ opacity: 0 }} />} </AnimatePresence> ``` **Stable keys for list animations:** ```jsx /* ❌ Index keys cause erratic animations */ {items.map((item, i) => <li key={i}>{item}</li>)} /* ✅ Stable IDs */ {items.map(item => <li key={item.id}>{item.text}</li>)} ``` **AutoAnimate parent must be unconditional:** ```jsx /* ❌ Ref can't attach to conditional element */ {showList && <ul ref={parent}>...</ul>} /* ✅ Parent always renders, children are conditional */ <ul ref={parent}>{showList && items.map(...)}</ul> ``` ## Library Selection | Library | Size | Best for | |---------|------|----------| | CSS only | 0kb | Hover states, simple transitions | | AutoAnimate | 3kb | Lists, accordions, toasts (90% of UI animations) | | Motion | 22kb | Gestures, physics, scroll animations, complex choreography | | GSAP | 60kb | Timelines, creative animation, scroll-triggered sequences | Start with CSS. Add AutoAnimate for list animations. Only add Motion/GSAP for complex needs. ## Common Mistakes - Animating `width`/`height` instead of `scale`—causes layout thrashing - Infinite animations without pause control—no way to stop - Same easing for enter and exit—use ease-out for enter, ease-in for exit - Ignoring prefers-reduced-motion—causes physical discomfort - Duration over 500ms—feels sluggish - `transition: all` catching unintended properties - Missing AnimatePresence for exit animations in React

标签

skill ai

通过对话安装

该技能支持在以下平台通过对话安装:

OpenClaw WorkBuddy QClaw Kimi Claude

方式一:安装 SkillHub 和技能

帮我安装 SkillHub 和 animations-1776419941 技能

方式二:设置 SkillHub 为优先技能安装源

设置 SkillHub 为我的优先技能安装源,然后帮我安装 animations-1776419941 技能

通过命令行安装

skillhub install animations-1776419941

下载 Zip 包

⬇ 下载 Animations v1.0.0

文件大小: 2.81 KB | 发布时间: 2026-4-17 20:14

v1.0.0 最新 2026-4-17 20:14
Initial release

Archiver·手机版·闲社网·闲社论坛·羊毛社区· 多链控股集团有限公司 · 苏ICP备2025199260号-1

Powered by Discuz! X5.0   © 2024-2025 闲社网·线报更新论坛·羊毛分享社区·http://xianshe.com

p2p_official_large
返回顶部