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

Ребят, подскажите использую react-window ( может это как-то влияет) меняя один

айтем в редаксе, перерисовываются все, а нужно только один, как пофиксить?

10 ответов

13 просмотров
PH_cheerokee- Автор вопроса

использую redux-toolkit

ну видимо нужно что бы бы каждый из айтемов, был memoизированным компонентом. https://ru.reactjs.org/docs/react-api.html#reactmemo

PH_cheerokee- Автор вопроса
Timofey Goncharov
ну видимо нужно что бы бы каждый из айтемов, был m...

export default React.memo(PatientTableRowContainer) <List ref={ref} outerRef={outerRef} style={{ width: "100%", ...style}} height={window.innerHeight} itemCount={patientsIds.length} onScroll={onScroll} itemSize={76} width={"100%"} > {({ index, style }: { index: number, style: any }) => ( <PatientTableRowContainer key={patientsIds[index]} {...{ patientID: patientsIds[index], index, style, canReadOnly, position, updateDatepickerPosition }} /> ) } </List>

PH_cheerokee
так и есть обернул

значит нарушаешь мемоизацию прокидывая объект/массив/стрелочную функцию

PH_cheerokee
export default React.memo(PatientTableRowContainer...

PatientTableRowContainer должен быть мемоизированным компонентом

PH_cheerokee
export default React.memo(PatientTableRowContainer...

там style прокидывается. скорее всего это объект который был только что в рендере создан. он и ломает мемоизацию. как я понимаю у тебя тут вартуализация списка, а значит перерндеревиваются не все, а только те что в радиусе видимости. если у тебя строки слишком тяжелые для ререндеринга, попробуй спустить оптимизацию ниже, для чилдренов компонента PatientTableRowContainer

PH_cheerokee- Автор вопроса
Timofey Goncharov
там style прокидывается. скорее всего это объект к...

очень странно( сделал так function customFunction(prevProps:any, nextProps:any) { if(!R.equals(prevProps, nextProps)){ return true } return false } export default React.memo(PatientTableRowContainer, customFunction) все равно ререндерит

PH_cheerokee
очень странно( сделал так function customFunction...

const mapProps = {}; Object .keys(prevProps) .forEach((key) => prevProps[key] !== nextProps[key] ? mapProps[key] = {prev: prevProps[key], next: nextProps[key]} : null ) вот такой код воткни в первую строку функции и законсоль mapProps что бы увидеть кто из пропсов изменяется и мешает мемоизации

PH_cheerokee
очень странно( сделал так function customFunction...

effector бы тебе сразу дал: 1. переключатель pending true/false 2. возможность мапить данные с сервера (изменять ответ с сервера под нужный формат для вьюшки) 3. расшаривать данные сразу на несколько компонентов если вдруг они там будут нужны 4. перегонять данные в разные сторы если вдруг данные потребовались за пределами определенной области и многое другое

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта