--- sidebar_position: 5 --- # Polling **Polling в React** — это техника, при которой клиент (например, веб-приложение) периодически отправляет запросы на сервер для получения обновленных данных. Это полезно, когда нужно поддерживать актуальность данных в реальном времени, но использование более продвинутых технологий, таких как **WebSockets** или **Server-Sent Events (SSE)**, невозможно или нецелесообразно. ## Как реализовать Polling в React: В React **polling** можно реализовать с помощью встроенных методов, таких как `setInterval`, или с использованием библиотек для управления состоянием и запросами, например, **React Query** или **Apollo Client**. ```jsx import React, { useState, useEffect } from 'react'; import axios from 'axios'; function PollingExample() { const [data, setData] = useState(null); const [loading, setLoading] = useState(true); useEffect(() => { const fetchData = async () => { try { const response = await axios.get('https://api.example.com/data'); setData(response.data); } catch (error) { console.error('Error fetching data:', error); } finally { setLoading(false); } }; // Первый запрос fetchData(); // Polling: запрос каждые 5 секунд const intervalId = setInterval(fetchData, 5000); // Очистка интервала при размонтировании компонента return () => clearInterval(intervalId); }, []); if (loading) return
Loading...
; return ({JSON.stringify(data, null, 2)}