--- title: Use SWR for Automatic Deduplication impact: MEDIUM-HIGH impactDescription: automatic deduplication tags: client, swr, deduplication, data-fetching --- ## Use SWR for Automatic Deduplication SWR enables request deduplication, caching, and revalidation across component instances. **Incorrect (no deduplication, each instance fetches):** ```tsx function UserList() { const [users, setUsers] = useState([]); useEffect(() => { fetch('/api/users') .then((r) => r.json()) .then(setUsers); }, []); } ``` **Correct (multiple instances share one request):** ```tsx import useSWR from 'swr'; function UserList() { const { data: users } = useSWR('/api/users', fetcher); } ``` **For immutable data:** ```tsx import { useImmutableSWR } from '@/lib/swr'; function StaticContent() { const { data } = useImmutableSWR('/api/config', fetcher); } ``` **For mutations:** ```tsx import { useSWRMutation } from 'swr/mutation'; function UpdateButton() { const { trigger } = useSWRMutation('/api/user', updateUser); return ; } ``` Reference: [https://swr.vercel.app](https://swr.vercel.app)