68 lines
3.0 KiB
Markdown
68 lines
3.0 KiB
Markdown
---
|
||
sidebar_position: 8
|
||
---
|
||
|
||
# Пользовательские хуки
|
||
|
||
Пользовательские хуки в React — это функции, которые позволяют вам использовать состояние и другие возможности React (например, эффекты, контекст и т.д.) в ваших компонентах, но с возможностью повторного использования логики. Пользовательские хуки помогают избежать дублирования кода и делают его более читаемым и поддерживаемым.
|
||
|
||
## Основные правила пользовательских хуков:
|
||
Имя пользовательского хука должно начинаться с use, чтобы React мог понять, что это хук, и применять к нему соответствующие правила (например, правила хуков).
|
||
|
||
Пользовательские хуки могут вызывать другие хуки, такие как useState, useEffect, useContext и т.д.
|
||
|
||
## Преимущества пользовательских хуков:
|
||
1. **Повторное использование логики:** Вы можете использовать одну и ту же логику в разных компонентах.
|
||
2. **Упрощение компонентов:** Логика выносится из компонента, что делает его более чистым и понятным.
|
||
3. **Тестируемость:** Пользовательские хуки можно тестировать отдельно от компонентов.
|
||
|
||
## Пример: хук для работы с localStorage
|
||
```jsx
|
||
import { useState } from 'react';
|
||
|
||
// Пользовательский хук useLocalStorage
|
||
function useLocalStorage(key, initialValue) {
|
||
const [storedValue, setStoredValue] = useState(() => {
|
||
try {
|
||
const item = window.localStorage.getItem(key);
|
||
return item ? JSON.parse(item) : initialValue;
|
||
} catch (error) {
|
||
console.log(error);
|
||
return initialValue;
|
||
}
|
||
});
|
||
|
||
const setValue = (value) => {
|
||
try {
|
||
const valueToStore = value instanceof Function ? value(storedValue) : value;
|
||
setStoredValue(valueToStore);
|
||
window.localStorage.setItem(key, JSON.stringify(valueToStore));
|
||
} catch (error) {
|
||
console.log(error);
|
||
}
|
||
};
|
||
|
||
return [storedValue, setValue];
|
||
}
|
||
|
||
// Использование хука в компоненте
|
||
function App() {
|
||
const [name, setName] = useLocalStorage('name', 'Гость');
|
||
|
||
return (
|
||
<div>
|
||
<input
|
||
type="text"
|
||
value={name}
|
||
onChange={(e) => setName(e.target.value)}
|
||
placeholder="Введите ваше имя"
|
||
/>
|
||
<p>Привет, {name}!</p>
|
||
</div>
|
||
);
|
||
}
|
||
|
||
export default App;
|
||
```
|
||
|
||
🚀 **_Источник: DeepSeek_** |