из useState же теперь нет коллбэка, для того, чтобы гарантированно вызвать что-то только после изменения стейта?
Весь оверфлоу завален "гениальным" решением с
setSome('123')//
useEffect(() => helpfulFunction, [some])
но это решение мне не подходит, так как коллбэк я хочу сделать в конкретном методе и some меняется не только в нем.
что-то вроде:
useEffect(() => setSome('onmount'), [])//тут some тоже меняется
const anotherChange = () => setSome('another')//и тут
const handleChange = () => setSome('123', () => helpfulFunction)//а тут мне нужен коллбэк
Это никак не сделать. Аналога колбека для this.setState в хуках нет и не будет из-за ограничений js как языка. const [a, setA] = useState('') У тебя невозможно получить в a новое значение без ререндера.
да только юзе еффект. Если нужно на конкретный метод то сделай проверку внутри эффекта
Хотя знаешь можно написать свою прослойку. И колбек записывать в реф. А на следующем рендере вызывать. Вангую есть такие уже кастомные хуки
насколько я понимаю, реализация на хуках идеологически подразумевает отсутствие такого рода коллбэков и для этого следует использовать useEffect
useEffect(() => {}, [someStateValue])
запиши новое значение some в локальную переменную в том месте, где оно меняется, передай ее в setSome и используй сразу там где нужно, не?
Обсуждают сегодня