Table des matières
Component et PureComponent ont une différence
Comparaison superficielle 101
Ne changez jamais
Vous rencontrez des problèmes de performances ?
Ne liez pas de valeurs dans la fonction de rendu
Ne dérivez pas de données dans la méthode de rendu
Maison interface Web js tutoriel Explication détaillée de la différence entre Component et PureComponent

Explication détaillée de la différence entre Component et PureComponent

May 24, 2018 pm 03:44 PM
component 详解

Cette fois, je vais vous donner une explication détaillée de la différence entre l'utilisation de Component et PureComponent. Quelles sont les précautions lors de l'utilisation de Component et PureComponent. jetez un oeil.

J'ai commencé à utiliser PureCompoent parce que c'était une version plus performante de Component. Bien que cela s’avère vrai, cette augmentation des performances s’accompagne de quelques mises en garde. Approfondissons un peu PureComponent et comprenons pourquoi nous devrions l'utiliser.

Component et PureComponent ont une différence

À l'exception de vous fournir une méthode shouldComponentUpdate avec une comparaison superficielle, PureComponent et Component sont fondamentalement identiques. Lorsque props ou state change, PureComponent effectuera une comparaison superficielle entre props et state. D'un autre côté, Component ne compare pas props et state dans les états actuel et suivant. Par conséquent, chaque fois que shouldComponentUpdate est appelé, le composant sera restitué par défaut.

Comparaison superficielle 101

Lors de la comparaison des props et state précédents et suivants, la comparaison superficielle vérifiera si la valeur d'origine a la même valeur (par exemple : 1 == 1 ou ture==true), si le tableau et l' objet référence sont identiques.

Ne changez jamais

Vous avez peut-être entendu dire, ne changez pas les objets et les tableaux dans props et state, si vous modifiez des objets dans votre composant parent, vos sous-composants "purs" le seront ne soit pas mis à jour. Bien que la valeur ait été modifiée, le sous-composant compare si la référence précédente de props est la même, sans effectuer de comparaison approfondie.

En revanche, vous pouvez renvoyer un nouvel objet en utilisant la méthode d'affectation es6 ou l'opérateur d'extension de tableau ou en utilisant une bibliothèque tierce pour obtenir l'immuabilité.

Vous rencontrez des problèmes de performances ?

Comparer les valeurs primitives et les références d'objets est une opération peu coûteuse. Si vous avez une liste d'objets enfants et que l'un d'entre eux est mis à jour, vérifier leurs props et state est beaucoup plus rapide que de restituer chaque nœud enfant

Autres solutions Solution

Ne liez pas de valeurs dans la fonction de rendu

Supposons que vous ayez une liste d'éléments et que chaque élément reçoive un paramètre unique à la méthode parent. Pour lier des paramètres, vous pouvez faire ceci :

<CommentItem likeComment={() => this.likeComment(user.id)} />
Copier après la connexion

Ce problème entraînera la création d'une nouvelle fonction à chaque fois que la méthode de rendu du composant parent est appelée, après l'avoir transmise à likeComment. Cela aura pour effet secondaire de modifier chaque composant enfant props, ce qui entraînera leur nouveau rendu, même si les données elles-mêmes n'ont pas changé.

Pour résoudre ce problème, transmettez simplement une référence à la méthode prototype du composant parent au composant enfant. La propriété likeComment du composant enfant aura toujours la même référence, il n'y aura donc pas de nouveaux rendus inutiles.

<CommentItem likeComment={this.likeComment} userID={user.id} />
Copier après la connexion

Créez ensuite une méthode de classe dans le composant enfant qui fait référence à l'attribut entrant :

class CommentItem extends PureComponent {
  ...
  handleLike() {
    this.props.likeComment(this.props.userID)
  }
  ...
}
Copier après la connexion

Ne dérivez pas de données dans la méthode de rendu

Pensez à it Le composant de configuration affichera les dix articles préférés de l'utilisateur parmi une série d'articles.

render() {
  const { posts } = this.props
  const topTen = posts.sort((a, b) => b.likes - a.likes).slice(0, 9)
  return //...
}
Copier après la connexion

Chaque fois que le composant restitue topTen aura une nouvelle référence, même si posts n'a pas changé et que les données dérivées sont les mêmes. Cela entraînera un nouveau rendu inutile de la liste.

Vous pouvez résoudre ce problème en mettant en cache vos données dérivées. Par exemple, définissez les données dérivées dans votre composant state afin qu'elles ne soient mises à jour que lorsque les publications sont mises à jour.

componentWillMount() {
  this.setTopTenPosts(this.props.posts)
}
componentWillReceiveProps(nextProps) {
  if (this.props.posts !== nextProps.posts) {
    this.setTopTenPosts(nextProps)
  }
}
setTopTenPosts(posts) {
  this.setState({
    topTen: posts.sort((a, b) => b.likes - a.likes).slice(0, 9)
  })
}
Copier après la connexion

Si vous utilisez Redux, pensez à utiliser reselect pour créer des « sélecteurs » pour combiner et mettre en cache les données dérivées.

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 Web chinois de php !

Lecture recommandée :

Explication détaillée de l'utilisation du cycle de vie dans React

Explication détaillée de l'utilisation de la communication des composants dans React

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 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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Explication détaillée de l'obtention des droits d'administrateur dans Win11 Explication détaillée de l'obtention des droits d'administrateur dans Win11 Mar 08, 2024 pm 03:06 PM

Le système d'exploitation Windows est l'un des systèmes d'exploitation les plus populaires au monde et sa nouvelle version Win11 a beaucoup attiré l'attention. Dans le système Win11, l'obtention des droits d'administrateur est une opération importante. Les droits d'administrateur permettent aux utilisateurs d'effectuer davantage d'opérations et de paramètres sur le système. Cet article présentera en détail comment obtenir les autorisations d'administrateur dans le système Win11 et comment gérer efficacement les autorisations. Dans le système Win11, les droits d'administrateur sont divisés en deux types : administrateur local et administrateur de domaine. Un administrateur local dispose de tous les droits d'administration sur l'ordinateur local

Explication détaillée de la fonction mode en C++ Explication détaillée de la fonction mode en C++ Nov 18, 2023 pm 03:08 PM

Explication détaillée de la fonction mode en C++ En statistiques, le mode fait référence à la valeur qui apparaît le plus fréquemment dans un ensemble de données. En langage C++, nous pouvons trouver le mode dans n’importe quel ensemble de données en écrivant une fonction de mode. La fonction mode peut être implémentée de nombreuses manières différentes, deux des méthodes couramment utilisées seront présentées en détail ci-dessous. La première méthode consiste à utiliser une table de hachage pour compter le nombre d'occurrences de chaque nombre. Tout d’abord, nous devons définir une table de hachage avec chaque nombre comme clé et le nombre d’occurrences comme valeur. Ensuite, pour un ensemble de données donné, nous exécutons

Explication détaillée du fonctionnement de la division dans Oracle SQL Explication détaillée du fonctionnement de la division dans Oracle SQL Mar 10, 2024 am 09:51 AM

Explication détaillée de l'opération de division dans OracleSQL Dans OracleSQL, l'opération de division est une opération mathématique courante et importante, utilisée pour calculer le résultat de la division de deux nombres. La division est souvent utilisée dans les requêtes de bases de données. Comprendre le fonctionnement de la division et son utilisation dans OracleSQL est donc l'une des compétences essentielles des développeurs de bases de données. Cet article discutera en détail des connaissances pertinentes sur les opérations de division dans OracleSQL et fournira des exemples de code spécifiques pour référence aux lecteurs. 1. Opération de division dans OracleSQL

Explication détaillée de la fonction reste en C++ Explication détaillée de la fonction reste en C++ Nov 18, 2023 pm 02:41 PM

Explication détaillée de la fonction reste en C++ En C++, l'opérateur reste (%) est utilisé pour calculer le reste de la division de deux nombres. Il s'agit d'un opérateur binaire dont les opérandes peuvent être n'importe quel type entier (y compris char, short, int, long, etc.) ou un type nombre à virgule flottante (tel que float, double). L'opérateur reste renvoie un résultat du même signe que le dividende. Par exemple, pour l'opération de reste des entiers, nous pouvons utiliser le code suivant pour implémenter : inta=10;intb=3;

Explication détaillée de l'utilisation de la fonction Vue.nextTick et de son application dans les mises à jour asynchrones Explication détaillée de l'utilisation de la fonction Vue.nextTick et de son application dans les mises à jour asynchrones Jul 26, 2023 am 08:57 AM

Explication détaillée de l'utilisation de la fonction Vue.nextTick et de son application dans les mises à jour asynchrones. Dans le développement de Vue, nous rencontrons souvent des situations où les données doivent être mises à jour de manière asynchrone. Par exemple, les données doivent être mises à jour immédiatement après la modification du DOM ou des opérations associées. à effectuer immédiatement après la mise à jour des données. La fonction .nextTick fournie par Vue a émergé pour résoudre ce type de problème. Cet article présentera en détail l'utilisation de la fonction Vue.nextTick et la combinera avec des exemples de code pour illustrer son application dans les mises à jour asynchrones. 1. Vue.nex

Explication détaillée de la méthode de réglage php-fpm Explication détaillée de la méthode de réglage php-fpm Jul 08, 2023 pm 04:31 PM

PHP-FPM est un gestionnaire de processus PHP couramment utilisé pour offrir de meilleures performances et stabilité PHP. Cependant, dans un environnement à forte charge, la configuration par défaut de PHP-FPM peut ne pas répondre aux besoins, nous devons donc l'ajuster. Cet article présentera en détail la méthode de réglage de PHP-FPM et donnera quelques exemples de code. 1. Augmentez le nombre de processus Par défaut, PHP-FPM ne démarre qu'un petit nombre de processus pour gérer les requêtes. Dans un environnement à charge élevée, nous pouvons augmenter la concurrence de PHP-FPM en augmentant le nombre de processus.

Explication détaillée du rôle et de l'utilisation de l'opérateur modulo PHP Explication détaillée du rôle et de l'utilisation de l'opérateur modulo PHP Mar 19, 2024 pm 04:33 PM

L'opérateur modulo (%) en PHP est utilisé pour obtenir le reste de la division de deux nombres. Dans cet article, nous discuterons en détail du rôle et de l'utilisation de l'opérateur modulo et fournirons des exemples de code spécifiques pour aider les lecteurs à mieux comprendre. 1. Le rôle de l'opérateur modulo En mathématiques, lorsqu'on divise un entier par un autre entier, on obtient un quotient et un reste. Par exemple, lorsque l’on divise 10 par 3, le quotient est 3 et le reste est 1. L'opérateur modulo est utilisé pour obtenir ce reste. 2. Utilisation de l'opérateur modulo En PHP, utilisez le symbole % pour représenter le module

Intervieweur : La différence entre @Configuration et @Component Intervieweur : La différence entre @Configuration et @Component Aug 15, 2023 pm 04:29 PM

L’appel de la méthode annotée @Bean dans la classe @Configuration renvoie le même exemple ; l’appel de la méthode annotée @Bean dans la classe @Component renvoie une nouvelle instance.

See all articles