Eu tenho um componente pai que processa uma coleção de filhos com base em uma matriz recebida via adereços.
import React from 'react';
import PropTypes from 'prop-types';
import shortid from 'shortid';
import { Content } from 'components-lib';
import Child from '../Child';
const Parent = props => {
const { items } = props;
return (
<Content layout='vflex' padding='s'>
{items.map(parameter => (
<Child parameter={parameter} key={shortid.generate()} />
))}
</Content>
);
};
Parent.propTypes = {
items: PropTypes.array
};
export default Parent;
Toda vez que um novo itemé adicionado, todos os filhos são renderizados novamente e eu estou tentando evitar isso. Eu não quero que outros filhos sejam renderizados novamente. Apenas quero renderizar o último que foi adicionado.
Então, tentei React.memo na criança em que provavelmente compararei pela codepropriedade ou algo assim. O problema é que a função de igualdade nunca é chamada.
import React from 'react';
import PropTypes from 'prop-types';
import { Content } from 'components-lib';
const areEqual = (prevProps, nextProps) => {
console.log('passed here') // THIS IS NEVER LOGGED!!
}
const Child = props => {
const { parameter } = props;
return <Content>{parameter.code}</Content>;
};
Child.propTypes = {
parameter: PropTypes.object
};
export default React.memo(Child, areEqual);
Alguma idéia do porquê?