Maison interface Web js tutoriel Explication détaillée de l'utilisation des accessoires et des attributs d'état dans React (exemple de code)

Explication détaillée de l'utilisation des accessoires et des attributs d'état dans React (exemple de code)

Dec 06, 2018 pm 03:45 PM
react.js 前端优化

Cet article vous apporte une explication détaillée de l'utilisation des accessoires et des attributs d'état dans React (exemples de code). Les amis dans le besoin peuvent s'y référer. Vous avez aidé.

Cet article présente principalement l'utilisation spécifique des accessoires et des attributs d'état React, qui ont une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. S'il y a des lacunes, les critiques et les corrections sont les bienvenues.

props

Je ne sais pas si vous vous souvenez encore des attributs dans la balise xml, comme ceci :

<class id="1">
 <student id="1">John Kindem</student>
 <student id="2">Alick Ice</student>
</class>
Copier après la connexion

Un tel fichier XML indique qu'il y a deux élèves dans la classe 1. L'élève avec le numéro d'élève 1 s'appelle John Kindem et l'élève avec le numéro d'élève 2 s'appelle Alick Ice. L'identifiant est l'attribut You. peut le mettre Traité comme une constante, il est en lecture seule.
html hérite de XML, et JSX est une extension de HTML et JS dans un certain sens. Le concept d'attributs a naturellement été hérité.
Dans React, nous utilisons le concept de props pour transmettre des valeurs en lecture seule aux composants React, comme ceci :

// 假设我们已经自定义了一个叫Hello的组件
ReactDom.render(
  <Hello firstName={&#39;John&#39;} lastName={&#39;Kindem&#39;}/>,
  document.getElementById('root')
);
Copier après la connexion

Lors de l'appel d'un composant React, nous pouvons le transmettre au composant comme ci-dessus Quelques constantes que le composant doit appeler en interne. La méthode d'appel est la suivante :

class Hello extends React.Component {
  constructor(props) {
    super(props);
  }
 
  render() {
    return (
      <p>
        <h1>Hello, {this.props.firstName + ' ' + this.props.lastName}</h1>
      </p>
    );//欢迎加入前端全栈开发交流圈一起学习交流:864305860
  }//面向1-3年前端人员
}//帮助突破技术瓶颈,提升思维能力
 
ReactDom.render(
  <Hello firstName={&#39;John&#39;} lastName={&#39;Kindem&#39;}/>,
  document.getElementById('root')
);
Copier après la connexion

Pour obtenir les accessoires passés à l'intérieur du composant, il vous suffit d'utiliser l'objet this.props, mais avant de l'utiliser, pensez à écraser le constructeur du composant, Et acceptez la valeur des accessoires pour appeler le constructeur de la classe parent.
Bien sûr, les accessoires peuvent également définir des valeurs par défaut, comme suit :

class Hello extends React.Component {
  constructor(props) {
    super(props);
  }
 
  static defaultProps = {
    firstName: 'John',
    lastName: 'Kindem'
  };
 
  render() {
    return (
      <div>
        <h1>Hello, {this.props.firstName + ' ' + this.props.lastName}</h1>
      </div>
    );//欢迎加入前端全栈开发交流圈一起吹水聊天学习交流:864305860
  }//面向1-3年前端人员
}//帮助突破技术瓶颈,提升思维能力
 
ReactDom.render(
  <Hello/>,
  document.getElementById('root')
);
Copier après la connexion

Déclarez simplement une valeur par défaut d'accessoires statiques dans la classe ES6, et l'effet d'exécution est le même que ci-dessus.
Les accessoires ne sont pas compliqués et peuvent être appris avec un peu de pratique.

état, cycle de vie des composants

Vous vous souvenez peut-être, que se passe-t-il si je souhaite ajouter des effets dynamiques à un composant React ? Ce problème doit être résolu en utilisant l'état du composant React. L'état signifie l'état. Dans React, toutes les variables de contrôle changeantes doivent être mises en état. Chaque fois que le contenu de l'état change, le composant correspondant de la page sera restitué. De plus, l'état est complètement interne au composant. L'état ne peut pas être transféré de l'extérieur vers l'intérieur, et la valeur de l'état ne peut pas non plus être modifiée directement.
Donnons d'abord un exemple :

import React from 'react';
import ReactDom from 'react-dom';
 
class Time extends React.Component {
  constructor(props) {
    super(props);
 
    // 初始化state
    this.state = {
      hour: 0,
      minute: 0,
      second: 0
    }
  }
  componentDidMount() {
    this.interval = setInterval(() => this.tick(), 1000);
  }
 
  componentWillUnmount() {
    clearInterval(this.interval);
  }
 
  tick() {
    // 计算新时间
    let newSecond, newMinute, newHour;
    let carryMinute = 0, carryHour = 0;
    newSecond = this.state.second + 1;
    if (newSecond > 59) {
      carryMinute = 1;
      newSecond -= 60;
    }
    newMinute = this.state.minute + carryMinute;
    if (newMinute > 59) {
      carryHour = 1;
      newMinute -= 60;
    }
    newHour = this.state.hour + carryHour;
    if (newHour > 59) newHour -= 60;
 
    // 设置新状态
    this.setState({
      hour: newHour,
      minute: newMinute,
      second: newSecond
    });
  }
 
  render() {
    return (
      <div>
        <h1>current time: {this.state.hour + ':' + this.state.minute + ':' + this.state.second}</h1>
      </div>
    );
  }
}
ReactDom.render(
  <Time/>,
  document.getElementById('root')
);
Copier après la connexion

De cette façon, un compteur est complété. La valeur change une fois par seconde. Expliquons le code : Tout d'abord, l'état est initialisé dans le constructeur, comme. this :

constructor(props) {
  super(props);
 
  // 在这初始化state
  this.state = {
    ...
  }
}
Copier après la connexion

Pour changer l'état, utilisez une fonction intégrée dans la classe de base du composant React :

this.setState({
  ...
});
Copier après la connexion

Assurez-vous de faire attention à la portée de ceci avant d'utiliser cette fonction, dans les fonctions fléchées, cela pointe vers this externe, tandis que this dans une fonction normale pointe vers la fonction elle-même.
De plus, les rappels du cycle de vie de deux composants React sont utilisés ici : `

componentDidMount() {
  // React组件被加载到dom中的时候被调用
  ...
}
componentWillUnmount() {
  // React组件从dom中卸载的时候被调用
  ...
}
Copier après la connexion

Le code de minuterie ci-dessus ne devrait donc pas être difficile une fois le composant React chargé dans le dom. pour mettre à jour l'état toutes les secondes. Lorsque l'état est mis à jour, les composants de la page seront restitués. Lorsque le composant est déchargé, la minuterie doit être effacée.
Cependant, React a une limite maximale pour la fréquence des mises à jour d'état. Le dépassement de cette limite entraînera une diminution des performances de rendu des pages. Vous devez faire attention à ne pas utiliser setState dans les fonctions à haute fréquence.


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

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

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)

Comment appeler la méthode du composant enfant dans le composant parent React Comment appeler la méthode du composant enfant dans le composant parent React Dec 27, 2022 pm 07:01 PM

Méthode d'appel : 1. Les appels dans les composants de classe peuvent être implémentés en utilisant React.createRef(), la déclaration fonctionnelle de l'attribut onRef personnalisé ref ou props ; 2. Les appels dans les composants de fonction et les composants Hook peuvent être implémentés en utilisant useImperativeHandle ou forwardRef pour lancer un La référence du composant enfant est implémentée.

Comment améliorer la vitesse d'accès du site Web Python grâce à l'optimisation front-end ? Comment améliorer la vitesse d'accès du site Web Python grâce à l'optimisation front-end ? Aug 05, 2023 am 10:21 AM

Comment améliorer la vitesse d'accès du site Web Python grâce à l'optimisation front-end ? Avec le développement d’Internet, la vitesse d’accès aux sites Web est devenue l’un des indicateurs importants de l’expérience utilisateur. Pour les sites Web développés avec Python, comment améliorer la vitesse d'accès grâce à l'optimisation frontale est un problème qui doit être résolu. Cet article présentera quelques techniques d'optimisation frontale pour aider à améliorer la vitesse d'accès des sites Web Python. Compresser et fusionner des fichiers statiques Dans les pages Web, les fichiers statiques tels que CSS, JavaScript et les images occuperont beaucoup de bande passante et de charge.

Assurer une méta-boîte WordPress maintenable : compléter la partie front-end Assurer une méta-boîte WordPress maintenable : compléter la partie front-end Aug 27, 2023 pm 11:33 PM

Dans cette série d'articles, nous passerons en revue quelques conseils et stratégies que vous pouvez utiliser pour créer un plugin WordPress plus maintenable, et nous ferons tout cela dans le contexte d'un plugin qui utilise des méta-boîtes à onglets. implémenté des fonctionnalités spécifiquement pour nos onglets et également implémenté une première zone de texte qui sera utilisée pour capturer certaines entrées de l'utilisateur. Pour ceux d'entre vous qui ont prêté attention, vous savez que nous avons seulement fait : Rendre les onglets fonctionnels Introduire un seul élément d'interface utilisateur avec lequel l'utilisateur peut interagir Nous n'avons pas suivi le processus réel de nettoyage, de validation et de sauvegarde des données, nous n'avons pas non plus pris la peine de présenter le reste des options Le contenu de la carte. C’est exactement ce que nous ferons dans les deux prochains articles. Concrètement, dans cet article, nous continuerons

Comment déboguer le code source de React ? Introduction aux méthodes de débogage utilisant plusieurs outils Comment déboguer le code source de React ? Introduction aux méthodes de débogage utilisant plusieurs outils Mar 31, 2023 pm 06:54 PM

Comment déboguer le code source de React ? L'article suivant expliquera comment déboguer le code source de React sous divers outils et présentera comment déboguer le véritable code source de React dans les projets contributeurs, create-react-app et vite. J'espère que cela sera utile à tout le monde !

Compréhension approfondie des Hooks personnalisés de React Compréhension approfondie des Hooks personnalisés de React Apr 20, 2023 pm 06:22 PM

Les Hooks personnalisés React sont un moyen d'encapsuler la logique des composants dans des fonctions réutilisables. Ils fournissent un moyen de réutiliser la logique d'état sans écrire de classes. Cet article présentera en détail comment personnaliser les hooks d'encapsulation.

Guide d'adaptation React Mobile : Comment optimiser l'effet d'affichage des applications frontales sur différents écrans Guide d'adaptation React Mobile : Comment optimiser l'effet d'affichage des applications frontales sur différents écrans Sep 29, 2023 pm 04:10 PM

Guide d'adaptation React Mobile : Comment optimiser l'effet d'affichage des applications frontales sur différents écrans Ces dernières années, avec le développement rapide de l'Internet mobile, de plus en plus d'utilisateurs sont habitués à utiliser les téléphones mobiles pour parcourir des sites Web et utiliser diverses applications. . Cependant, les tailles et résolutions des différents écrans de téléphones mobiles varient considérablement, ce qui pose certains défis au développement front-end. Pour que le site Web et l'application aient de bons effets d'affichage sur différents écrans, nous devons nous adapter au terminal mobile et optimiser le code front-end en conséquence. Utiliser la mise en page réactive La mise en page réactive est un

Comment définir la hauteur du div en réaction Comment définir la hauteur du div en réaction Jan 06, 2023 am 10:19 AM

Comment définir la hauteur div dans React : 1. Implémentez la hauteur div via CSS ; 2. Déclarez un objet C dans l'état et stockez le style du bouton de modification dans l'objet, puis récupérez A et réinitialisez le "marginTop" en C. .C'est Can.

Pourquoi React n'utilise pas Vite comme premier choix pour créer des applications Pourquoi React n'utilise pas Vite comme premier choix pour créer des applications Feb 03, 2023 pm 06:41 PM

Pourquoi React n'utilise-t-il pas Vite comme premier choix pour créer des applications ? L'article suivant vous expliquera les raisons pour lesquelles React ne recommande pas Vite comme recommandation par défaut. J'espère que cela sera utile à tout le monde !

See all articles