Maison > interface Web > js tutoriel > Comment transmettre des accessoires personnalisés aux composants du routeur dans React Router v4 ?

Comment transmettre des accessoires personnalisés aux composants du routeur dans React Router v4 ?

Patricia Arquette
Libérer: 2024-10-30 14:27:03
original
708 Les gens l'ont consulté

How to Pass Custom Props to Router Components in React Router v4?

Passer des accessoires personnalisés aux composants du routeur dans React Router v4

Lors de la création d'applications React avec React Router, il est souvent nécessaire de transmettre des accessoires personnalisés aux composants enfants dans l’arborescence de routage. Dans React Router v4, l'accès aux accessoires transmis via le routeur peut poser des problèmes, car this.props.route peut ne pas toujours être disponible.

Pour résoudre ce problème, une approche consiste à utiliser l'accessoire de rendu pour le composant Route. . Cela permet l'intégration des définitions de composants et un rendu pratique sans avoir besoin de fichiers de composants séparés.

Selon la documentation de React Router, le prop de rendu pour Route reçoit les mêmes accessoires de route que le prop de rendu du composant. Par conséquent, il est possible de passer des props personnalisés en modifiant la définition de Route comme suit :

<Route path="/" exact render={(props) => (<Home test="hi" {...props}/>)} />
Copier après la connexion

Au sein du composant enfant (Home), le prop personnalisé est accessible via this.props.test :

this.props.test 
Copier après la connexion

Il est important de noter que l'opérateur de propagation {...props} doit être utilisé dans la définition de la route pour garantir que les accessoires de routeur par défaut (tels que l'emplacement, l'historique et la correspondance) sont également transmis à l'enfant. composant.

En tirant parti de l'accessoire de rendu, les développeurs peuvent facilement transmettre des accessoires personnalisés aux composants du routeur enfants dans React Router v4, améliorant ainsi la flexibilité et la maintenabilité de leur architecture de routage.

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:php.cn
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal