- Created `openspec-ff-change` skill for fast-forward artifact creation. - Introduced `openspec-new-change` skill for structured change creation. - Developed `openspec-onboard` skill for guided onboarding through OpenSpec workflow. - Added `openspec-sync-specs` skill for syncing delta specs to main specs. - Implemented `openspec-verify-change` skill for verifying implementation against change artifacts. - Updated `.gitignore` to exclude OpenSpec generated files. - Added `skills-lock.json` to manage skill dependencies.
41 lines
1.0 KiB
Markdown
41 lines
1.0 KiB
Markdown
---
|
|
title: Use Transitions for Non-Urgent Updates
|
|
impact: MEDIUM
|
|
impactDescription: maintains UI responsiveness
|
|
tags: rerender, transitions, startTransition, performance
|
|
---
|
|
|
|
## Use Transitions for Non-Urgent Updates
|
|
|
|
Mark frequent, non-urgent state updates as transitions to maintain UI responsiveness.
|
|
|
|
**Incorrect (blocks UI on every scroll):**
|
|
|
|
```tsx
|
|
function ScrollTracker() {
|
|
const [scrollY, setScrollY] = useState(0)
|
|
useEffect(() => {
|
|
const handler = () => setScrollY(window.scrollY)
|
|
window.addEventListener('scroll', handler, { passive: true })
|
|
return () => window.removeEventListener('scroll', handler)
|
|
}, [])
|
|
}
|
|
```
|
|
|
|
**Correct (non-blocking updates):**
|
|
|
|
```tsx
|
|
import { startTransition } from 'react'
|
|
|
|
function ScrollTracker() {
|
|
const [scrollY, setScrollY] = useState(0)
|
|
useEffect(() => {
|
|
const handler = () => {
|
|
startTransition(() => setScrollY(window.scrollY))
|
|
}
|
|
window.addEventListener('scroll', handler, { passive: true })
|
|
return () => window.removeEventListener('scroll', handler)
|
|
}, [])
|
|
}
|
|
```
|