Maison  >  Article  >  interface Web  >  Résumé des méthodes de transfert de données des composants parent-enfant Vue (avec code)

Résumé des méthodes de transfert de données des composants parent-enfant Vue (avec code)

php中世界最好的语言
php中世界最好的语言original
2018-05-12 15:44:582900parcourir

Cette fois, je vous apporte un résumé de la méthode de transfert de données du composant parent-enfant Vue (avec code). Quelles sont les précautions dans le résumé de la méthode de transfert de données du composant parent-enfant Vue). . Ce qui suit est un cas pratique, jetons un coup d'œil.

Lorsque nous écrivons le composant vue, nous pouvons utiliser le transfert de données ; pour transmettre les données du composant parent au composant enfant, parfois nous devons également transmettre le composant enfant à l'événement <.> Pour déclencher l'événement du composant parent ;

Chaque fois que nous rencontrons un tel besoin, nous pensons toujours à trois solutions :

Le transmettre au composant enfant via

(Parent- composant enfant)props

Effectuer la gestion de l'état (composant parent-enfant et composant non-parent-enfant) vuexvuex

Transfert de communication du composant non-parent-enfant

, utiliser Vue instances pour implémenter la surveillance des événements et la publication pour implémenter le transfert entre les composants. Vue Event Bus

Plus tard, lorsque j'ai visité la communauté, j'ai découvert qu'il existe un quatrième mode de livraison,

+ inheritAttrs + $attrs$listeners

Ci-joint le lien original dans la version Vue2.4 Les attributs

et attrs listeners nouvellement ajoutés utilisation et les meilleures pratiques de Vue.js (cinq conseils pour faire de vous un maître de Vue.js)

sont essentiellement utilisés par la plupart des entreprises ou des projets Les deux premiers sont utilisés, et notre entreprise ne fait pas exception ; il me semble l'avoir vu dans des documents officiels,

convient à une utilisation dans de grands projets. J'ai utilisé la troisième méthode dans la conception de mon diplôme, mais je ne pense pas l'avoir vue ailleurs, à cette époque, il n'y avait qu'une seule fonction nécessaire pour transférer des données entre des composants frères et sœurs. Utiliser vuex serait excessif. cela nécessite également du temps. J'ai donc choisi vuex pour la dernière méthode, je ne l'ai pas encore vue appliquée dans des projets. Mais personnellement, je pense que puisqu'il y a ceci Vue Event Bus, il doit y avoir une raison à son existence. Sinon, à quoi sert son existence ? ? S'il y a un besoin, je pense personnellement que vous pouvez l'essayer ; accepter le changement et saisir les opportunités api

Après avoir travaillé, j'ai découvert que

parfois, la méthode conventionnelle n'est pas nécessairement la meilleure. Il est peut-être préférable de sortir des sentiers battus et de résoudre les problèmes de manière originale. Les méthodes conventionnelles peuvent résoudre le problème, mais elles sont quelque peu lourdes. Il est plus intéressant d'en faire l'expérience dans la fosse minière réelle bug

+ inheritAttrs + $attrs$listeners

 : La valeur par défaut est inheritAttrstrue

Mon explication Autrement dit : les propriétés du composant parent qui ne sont pas héritées par le composant enfant ne seront pas affichées en tant qu'attributs sur l'élément racine du composant enfant. En parlant de ça, cela semble un peu gênant. Il suffit de regarder les captures d'écran et le code et vous comprendrez

inheritAttrs :false

c='ture1.png'>

Explication officielle : par défaut, la portée parent n'est pas reconnue comme une liaison de fonctionnalité de Defined (

) "retombera" et sera appliqué à l'élément racine du composant enfant comme un attribut. Lors de l'écriture d'un composant qui encapsule un élément cible ou un autre composant, cela peut ne pas toujours être conforme au

comportementinheritAttrs :false attendu. En définissant

sur

, ces comportements par défaut seront supprimés. Ces fonctionnalités peuvent être rendues efficaces via l'attribut d'instance (également nouveau dans la version 2.4) et peuvent être explicitement liées à des éléments non root via .

propsMon explication est la suivante : stocker les données qui ne sont pas héritées par les sous-composants attribute bindingsObjetsHTML regardez l'imageinheritAttrs; false

Explication officielle du document : contient des liaisons de fonctionnalités (à l'exception de la classe et du style) qui ne sont pas reconnues (et obtenues) en tant qu'accessoires dans la portée parent. Lorsqu'un composant ne déclare aucun accessoire, toutes les liaisons de portée parent (sauf la classe et le style) seront incluses ici, et les composants internes peuvent être transmis via v-bind="$attrs" - lors de la création de composants de haut niveau. Très utile.

$listeners

Ma compréhension est la suivante : les composants enfants peuvent déclencher des événements de composants parents (il n'est pas nécessaire d'utiliser ces vuex gênants ou une instance Vue vide comme bus d'événements, ou Qu'est-ce que c'est déjàvm.$on )

Je pense que vous maîtrisez la méthode après avoir lu le cas dans cet article. Pour des informations plus intéressantes, veuillez prêter attention aux autres articles connexes. sur le site PHP chinois !

Lecture recommandée :

Explication détaillée de l'utilisation du routage imbriqué vue et de la redirection 404

Configuration globale du projet Vue WeChat Description des étapes de partage

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!

Déclaration:
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