169 похожих чатов

Всем привет! const Comp = (): JSX.Element => {

const someMutableVar = useRef(null);

const callAPI = useCallback(() => {
someMutableVar.current = data;

void API.getAppData({ params: someMutableVar.current});
}, []);

return (
<>
....
<button onClick={callAPI}>Call API</button>
</>
);
};
ругается, что нельзя использовать присваивание someMutableVar.current так как свойство .current только для чтения, но и использовать useRef внутри useCallback низзя!

как быть?

(данный код синтетический - главный вопрос как установить someMutableVar.current внутри useCallback)

24 ответов

4 просмотра

кто ругается про только для чтения?

Roman Usherenko
кто ругается про только для чтения?

react => interface RefObject<T> { readonly current: T | null; }

В @ts_cool Вообще там есть отдельный тип MutableRef

Здесь не нужен useCallback

Кирилл
Здесь не нужен useCallback

предлагаете при каждой перерисовке вызывать апи?

Кирилл
путаешь с useEffect

да не вызов а создание clickHandler

Вадим Бударин Бударин
да не вызов а создание clickHandler

так ты на каждый rerender вызываешь useCallback и создаешь новую ссылку

Кирилл
путаешь с useEffect

я написал что код синтетический - в реальности clickHandler зависит от других переменных и чтобы избежать его пересоздания при перерисовках использцется useCallback с зависимостями

Кирилл
прочитай про useCallback в общем, ты не прав

да и собственно вопрос не в этом

Вадим Бударин Бударин
в чем я ошибаюсь?

я написал выше, почитай доку теперь)

Кирилл
так ты на каждый rerender вызываешь useCallback и ...

не создаю каждый раз новую - на самом деле в реальном коде там есть зависимости

Вадим Бударин Бударин
не создаю каждый раз новую - на самом деле в реаль...

зависимости не освобождают от пересоздания, другое дело useEffect

Кирилл
так ты на каждый rerender вызываешь useCallback и ...

"Как работает useCallback hook? Этот hook возвращает закешированную функцию (то есть ссылка не изменяется от рендера к рендеру). Помимо функции, которую нужно кешировать, в нее передан второй аргумент — пустой массив. Этот массив позволяет передать список полей, при изменении которых необходимо изменить функцию, т.е. вернуть новую ссылку."

Кирилл
это же не дока

useCallback const memoizedCallback = useCallback( () => { doSomething(a, b); }, [a, b], ); Возвращает мемоизированный колбэк.

Вадим Бударин Бударин
useCallback const memoizedCallback = useCallback( ...

Это полезно при передаче колбэков оптимизированным дочерним компонентам, которые полагаются на равенство ссылок для предотвращения ненужных рендеров (например, shouldComponentUpdate).

Кирилл
Это полезно при передаче колбэков оптимизированным...

это я понимаю - поэтому и написал что код синтетический

Похожие вопросы

Обсуждают сегодня

А как старый хаскел с новым стыковать ? потому как тут работает https://play.haskell.org/saved/C3xpMzcd, а вот тут https://stepik.org/lesson/7602/step/9?unit=1473 нет ошибка C...
Fedor
131
что насчет пагинга? на осдеве непонятно(
Vi Chapmann 🪙
26
Вопрос я правильно понимаю что в коде newtype ArrowMap k v = ArrowMap { getArrowMap :: k -> Maybe v } getArrowMap есть функция типа k -> Maybe v, если да, то не понимаю задач...
Fedor
64
Ребят, что лучше для реверса: гидра или ида?
En Vind Av Sorg
26
Делаю велосипед логгер. К сообщению хочу прикрутить некоторую информацию, типа, кем отправлено, какой уровень, и всякое такое. И тут подумалось мне, почему бы не хранить весь...
Serjone
24
Как Вы считаете нормально ли в двадцатых годах 21 века в ВУЗах Российской Федерации обучать студентов работе с TASM? Не слишком ли это "архаично"? (Если оффтоп или флейм для э...
Spiker01
52
Комрады, хотел уточнить. Проперть в OnDestroy юнита-хозяина по-прежнему доступна? И еще уточнение: finalization юнита наступает раньше или позже OnDestroy?
Ed Doc
48
Продолжая диалог про свифт в проде – сейчас возник вопрос в активном наборе бекендеров. В основном в нашей компании мы фанаты Java Spring и полностью ей довольны. Однако найм ...
Guseyn
27
если загрузчик efi? если сама PML4 PDPT PDT PT лежит в неудобном для меня месте?
Vi Chapmann 🪙
8
Читаю сейчас [нет, уже больше не читаю!] курсовую о Булгакове, написанную, похоже, с помощью ChatGPT. Это удивительный психоделический опыт. Текст в основном написан в стиле б...
✨ Uni [🌊 В отпуске]
1
Карта сайта