Maison > interface Web > js tutoriel > Comment implémenter plusieurs références pour un tableau d'éléments avec des crochets React ?

Comment implémenter plusieurs références pour un tableau d'éléments avec des crochets React ?

Susan Sarandon
Libérer: 2024-11-03 05:23:02
original
654 Les gens l'ont consulté

How to Implement Multiple Refs for an Array of Elements with React Hooks?

Utilisation de plusieurs références pour un tableau d'éléments avec des crochets

Question :

Comment peut-on plusieurs références peuvent-elles être implémentées pour un tableau d'éléments à l'aide de l'API React hooks ?

Contexte :

L'utilisation de références pour un seul élément est simple, mais l'étendre à un tableau des éléments nécessite une approche différente.

Solution proposée :

Étant donné que les crochets ne peuvent pas être utilisés dans les boucles, une approche personnalisée est nécessaire :

Étape 1 : Créer un tableau de références

Commencez par créer un objet ref qui contiendra une liste de références.

<code class="javascript">const itemsRef = useRef([]);</code>
Copier après la connexion

Étape 2 : Accéder aux références des éléments

Chaque élément du tableau est accessible à l'aide de l'index :

<code class="javascript">itemsRef.current[n] // nth element's ref</code>
Copier après la connexion

Étape 3 : Mettre à jour le tableau de référence en cas de changement de tableau

Assurez-vous que le tableau ref reste synchronisé avec le tableau d'éléments. Cela peut être fait dans un hook useEffect :

<code class="javascript">useEffect(() => {
  itemsRef.current = itemsRef.current.slice(0, props.items.length);
}, [props.items]);</code>
Copier après la connexion

Étape 4 : Attribuer des références aux éléments du tableau

Lors de la création des éléments, attribuez la référence appropriée à chacun :

<code class="javascript">props.items.map((item, i) => (
  <div
    key={i}
    ref={el => itemsRef.current[i] = el}
    style={{ width: `${(i + 1) * 100}px` }}
  >
    ...
  </div>
));</code>
Copier après la connexion

En suivant ces étapes, vous pouvez utiliser avec succès plusieurs références pour un tableau d'éléments avec des hooks.

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