Maison > interface Web > js tutoriel > React Hook dans le composant de classe

React Hook dans le composant de classe

PHPz
Libérer: 2024-09-07 15:00:32
original
351 Les gens l'ont consulté

React Hook in Class Component

Introduction

Dans certains scénarios, supposons que vous deviez le faire, utilisez le concept de hook React dans les composants basés sur la classe React.

Mais comme vous le savez, les hooks de réaction ne fonctionneront dans un composant fonctionnel que si vous souhaitez les utiliser directement dans un composant basé sur la classe.

ce sera dû à une erreur.

Alors, comment faire, il existe une solution de contournement pour la même chose.

Il existe une solution en 3 étapes

  1. Créez un Hook personnalisé, (Vous pouvez utiliser directement le hook, mais là, vous n'obtiendrez pas plus d'avantages)
  2. Utilisez le hook dans un composant d'ordre supérieur
  3. Nous devons envelopper le composant d'ordre supérieur dans un composant basé sur la classe.

Créer un Hook personnalisé

import {useState} from 'react';

const useGreet = () => {
  const [text, setText] = useState('');

//... do any additional operation / hooks you want to add

return text;   
}
Copier après la connexion

Création d'un composant d'ordre supérieur

// import useGreet

export const MyHigherOrderComponentDemo = (Component) => {

  return (props) => {
    const text = useGreet();

    return <Component text={text} {...props}/>;
  }
}
Copier après la connexion

Envelopper le composant d'ordre supérieur dans un composant basé sur la classe

// import useGreet

class MyClass extends React.component {

render() {
   return (
    <p>{this.props.text}</p>
  )
}

}

export default MyHigherOrderComponentDemo(MyClass);
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:dev.to
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal