Хук useEffect — это фундаментальная часть React, позволяющая выполнять побочные эффекты в функциональных компонентах. Вот подробная разбивка:
useEffect(() => { // Your side effect code here return () => { // Cleanup code (optional) }; }, [dependencies]);
Функция эффекта: первый аргумент — это функция, содержащая код побочного эффекта. Эта функция будет запущена после того, как рендеринг будет зафиксирован на экране.
Функция очистки (необязательно): функция эффекта может возвращать функцию очистки, которую React будет вызывать при размонтировании компонента или перед повторным запуском эффекта. Это полезно для очистки подписок или таймеров.
Массив зависимостей: второй аргумент представляет собой массив зависимостей. Эффект срабатывает только при изменении одной из зависимостей. Если вы передаете пустой массив ([]), эффект запускается только один раз после первоначального рендеринга (например, компонентDidMount).
import React, { useEffect, useState } from 'react'; const DataFetchingComponent = () => { const [data, setData] = useState(null); useEffect(() => { fetch('https://api.example.com/data') .then(response => response.json()) .then(data => setData(data)) .catch(error => console.error('Error fetching data:', error)); }, []); // Runs only once after the initial render return{data ? JSON.stringify(data) : 'Loading...'}; };
import React, { useEffect } from 'react'; const EventListenerComponent = () => { useEffect(() => { const handleResize = () => { console.log('Window resized:', window.innerWidth); }; window.addEventListener('resize', handleResize); // Cleanup function to remove the event listener return () => { window.removeEventListener('resize', handleResize); }; }, []); // Runs only once after the initial render returnResize the window and check the console.; };
import React, { useEffect, useState } from 'react'; const TimerComponent = ({ delay }) => { const [count, setCount] = useState(0); useEffect(() => { const timer = setInterval(() => { setCount(prevCount => prevCount 1); }, delay); // Cleanup function to clear the timer return () => clearInterval(timer); }, [delay]); // Runs every time `delay` changes returnCount: {count}; };
Хук useEffect — это мощный инструмент для обработки побочных эффектов в функциональных компонентах, что делает его незаменимым для современной разработки React. Понимая его синтаксис и лучшие практики, вы сможете эффективно управлять поведением компонентов и побочными эффектами.
Отказ от ответственности: Все предоставленные ресурсы частично взяты из Интернета. В случае нарушения ваших авторских прав или других прав и интересов, пожалуйста, объясните подробные причины и предоставьте доказательства авторских прав или прав и интересов, а затем отправьте их по электронной почте: [email protected]. Мы сделаем это за вас как можно скорее.
Copyright© 2022 湘ICP备2022001581号-3