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

Вопрос к адептам функциональных компонетов. Как вот такой пример переписать

без класса (речь о компоненте EditableTable)? Столкнулся с проблемой, что если в лоб методы переписать в тело FC, то получается, что при вызове handleAdd происходит иммутабильное обновление стейта (как оно, собственно, и должно быть), а метод handleDelete продолжает смотреть в скоуп старого компонента, т.к. был в нём объявлен и dataSource соответственно не поменяется...
https://codesandbox.io/s/7cxdm?file=/index.js

13 ответов

6 просмотров
Alexandr- Автор вопроса

Мой кривой перенос на FC выглядит вот так. https://codesandbox.io/s/editable-cells-antd484-forked-j3q7l?file=/index.js

handleDelete = (key) => { const dataSource = [...this.state.dataSource]; this.setState({ dataSource: dataSource.filter((item) => item.key !== key), count: this.state.count - 1 });

Alexandr- Автор вопроса
Денис
handleDelete = (key) => { const dataSource = [...

Да, вопрос заключается в том, как перенести этот классовый метод в функциональный компонент.

Alexandr- Автор вопроса
Alexandr
Да, вопрос заключается в том, как перенести этот к...

И при этом иметь из него доступ к актуальному состоянию стейта.

Alexandr
Да, вопрос заключается в том, как перенести этот к...

const [data, setData] = useState(); const [count, setCounter] = useState(0) Или я не правильно понял тебя?)

Alexandr
И при этом иметь из него доступ к актуальному сост...

setFoo(prevFoo => bar(prevFoo)) если не ошибаюсь (я просто на это поменял в песочнице и у меня удаление работает, поэтому вот)

Alexandr- Автор вопроса
Stanislav
setFoo(prevFoo => bar(prevFoo)) если не ошибаюсь (...

Ты имеешь ввиду использовать старый массив и в него запушить новый элемент?

Alexandr
И при этом иметь из него доступ к актуальному сост...

вопрос в том, как сделать так, чтобы метод объявленный в одной функции, был доступен в другой функции?))

Alexandr- Автор вопроса
Stanislav
это я про код в handleDelete тут

Не понял о чем ты, но проблему нашёл, в useMemo надо было список зависимостей передать просто.

Alexandr
Не понял о чем ты, но проблему нашёл, в useMemo на...

тогда выходит я вашу проблему не понял. впрочем раз она решена уже неважно.

Alexandr- Автор вопроса
Stanislav
тогда выходит я вашу проблему не понял. впрочем ра...

Проблема была в том, что удаление не работало

Alexandr- Автор вопроса
Alexandr
Мой кривой перенос на FC выглядит вот так. https:/...

Всё, дошло, есть второй способ решения, который позволяет оставить столбцы неизменными, надо рили просто коллбэк заюзать в сетСтейт. https://codesandbox.io/s/editable-cells-antd484-forked-j3q7l?file=/index.js

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

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

комрады, че-та лыжы не едут var tmpFont: TFont; begin tmpFont:= TFont.Create; try case rgFontColor.ItemIndex of 0: tmpFont.Color:= clWindowText; 1: tmpFo...
Ed Doc
34
Интересно, нет ли какого-то способа получить из dll не адрес самой метки, а адрес со смещением?
The Bird of Hermes
54
Можно вообще написать: Person fName' lName' age'. Тогда действительно имена полей потребуются лишь в строковом виде, чтобы эти fName' и т.д. достать :-) Но разве для этого нуж...
Михаил
8
generic procedure function test<T>(param: T); type case T of longint: NewT = word; longword: NewT = byte; end; var v1: NewT; Как это можно сделать? Чтобы у меня...
notme
21
Делал задачу вот такую https://stepik.org/lesson/4985/step/9?unit=1083 получилось такое https://play.haskell.org/saved/ipKrepqe оно работает, тестов много не писал, но работае...
Fedor
22
Скажите, можно ли как-то "переместить" динамический массив из одной переменной в другую? Скажем, переместить из TList<> в TArray<>. Именно переместить, а не скопировать. Если ...
Eugene Krasnikov (ᴊɪɴ x)
36
преобразовать в число или в один тип?
Alexey Kulakov
11
Hello everyone I am trying to run 4 year old project and I am having this issue anyone can help?
Nitish Garg
11
Всем привет, прошу совета по сложившейся ситуации: Windows приложение подключается к БД MySQL используя Firedac. При работе с версией MySQL 5.7 все отлично, но когда подключаю...
Constantine
6
Всем добрый вечер. Нужна помощь с прикруткой telegram-vapor-bot к проекту Vapor. Удалось после старта приложения отправить тестовое сообщение в бот, вот только сразу после это...
advanc3d
3
Карта сайта