Как организовать optimistic update?
Что хотят услышать интервьюеры:
Коротко: Optimistic update временно показывает ожидаемый результат до ответа сервера и откатывает его при ошибке.
Ответ:
Что важно сказать на собеседовании: На собеседовании важно связать эту тему с реальной render-моделью React: где источник данных, что вызывает обновление, какие побочные эффекты допустимы и как это влияет на поддержку интерфейса.
Пример (React/TSX):
const mutation = useMutation({
mutationFn: updateTodo,
onMutate: async (todo) => {
const previous = queryClient.getQueryData(['todos']);
queryClient.setQueryData(['todos'], (old) => patchTodo(old, todo));
return { previous };
},
onError: (_err, _todo, ctx) => queryClient.setQueryData(['todos'], ctx.previous),
}); Типичные ошибки: Типичная ошибка — отвечать только синтаксисом и не объяснять, как решение поведёт себя при повторном render, смене props, unmount или росте данных.
Практический контекст: В практике это встречается в формах, списках, dashboards, личных кабинетах и компонентах design-system; сильный ответ показывает не только API, но и границы применения.