Integrando React Hooks em componentes de classe React existentes
Como você observou, os React Hooks oferecem uma abordagem alternativa para gerenciar estado e lógica em Aplicativos de reação. No entanto, você pode querer migrar gradualmente seus componentes baseados em classe existentes para aproveitar as vantagens dos ganchos.
Felizmente, existe uma solução para esse desafio: componentes de ordem superior (HOCs). HOCs fornecem uma maneira de envolver seu componente de classe com uma função que injeta funcionalidade baseada em gancho.
Criando um HOC com Hooks
Para criar um HOC que integra um React hook, siga estas etapas:
Exemplo:
Suponha que você tenha um componente de classe chamado MyDiv:
class MyDiv extends React.component { constructor(){ this.state={sampleState:'hello world'} } render(){ return{this.state.sampleState}} }
Para adicionar um estado baseado em gancho ao MyDiv, você pode criar um HOC:
function withMyHook(Component) { return function WrappedComponent(props) { const myHookValue = useMyHook(); return; } }
Integrando o HOC
Agora, você pode agrupar seu componente de classe MyDiv com o withMyHook HOC:
class MyComponent extends React.Component { render(){ const myHookValue = this.props.myHookValue; return{myHookValue}; } } export default withMyHook(MyComponent);
Ao usar esta técnica, você pode integrar gradualmente ganchos React em sua base de código baseada em classe existente sem refatoração significativa.
Isenção de responsabilidade: Todos os recursos fornecidos são parcialmente provenientes da Internet. Se houver qualquer violação de seus direitos autorais ou outros direitos e interesses, explique os motivos detalhados e forneça prova de direitos autorais ou direitos e interesses e envie-a para o e-mail: [email protected]. Nós cuidaremos disso para você o mais rápido possível.
Copyright© 2022 湘ICP备2022001581号-3