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

Const [isLoading, setLoading] = useState(false) const [isData, setData] =

useState(data)
const [burger, setBurger] = useState(true)
const [address, setAddres] = useState<string>('')
const [cords, setCords] = useState({ lat: 45.035667, lng: 38.976389 })

const handleMaps = useCallback(async () => {
if (isData) {
const { data } = await axios.post(https://nominatim.openstreetmap.org/search?format=json&q=${address})
setCords({ ...cords, lat: data[0].lat, lng: data[0].lon })
}
}, [address, cords, isData])

useEffect(() => {
handleMaps()
}, [handleMaps])

Почему useEffect вызывает бесконечно функцию?

4 ответов

11 просмотров

потому что рекурсия. В зависимостях указал, что при изменении handleMaps вызови handleMaps... Вот он и вызывает и бесконечно попадает в useEffect. Убери handleMaps из зависимостей

У тебя useCallback зависит от cords и меняет их же. То есть код, который меняет cords, выполняется, когда меняется cords. Чтобы этого избежать, убери из зависимостей cords, а в setCords используй коллбэк

setCords(c => ({ ...c, lat: data[0].lat, lng: data[0].lon }))

А вообще, зачем тебе спредить старое значение, если ты устанавливаешь все поля из запрошенных данных? setCords({ lat: data[0].lat, lng: data[0].lon })

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

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

Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
10
А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
52
А дальше что?.. Записать в файл, потом в Код?.. И потом разбирать как-то?..
Хаскель Моисеевич Гопник
14
доброго времени. db, dw и прочие исполняются при трансляции или при выполнении программы?
lutayyy
10
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
например asm AT&T ... label: .string "hi" ... # not error lea label(%rip), %rax # error ( not compile ) mov %rip, %rax # not error mov (%rip), %rax из форумов прочитал чт...
Simple Sorcerer
6
Почему никто не подсказал, что можно объявить свои типы данных, в которых меньше полей, чем в отданном джейсоне, и добавлять их по необходимости?
Strange Rabbit
10
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
86
Есть предложения, как подобное можно упростить?
Hemul GM
12
Карта сайта