Partage
  • Partager sur Facebook
  • Partager sur Twitter

Strapi et react , afficher UN element de la bdd

Sujet résolu
    22 juin 2022 à 13:12:54

    Bonjour à tous,

    J'apprends react avec strapi.

    J'ai des éléments dans une base de données et j'arrive à tous les afficher sans problème.

    J'aimerais que lorsque l'on clique sur un élément on voit les informations de celui-ci.

    Je récupère donc l'id du lien sans problème et j'arrive à afficher les informations sauf que ça ne marche qu'une seule fois. En fait, si je clique sur le second élément j'ai un message d'erreur.

    Voici le code

    import React, {useRef,useEffect, useState, Fragment} from 'react'
    import axios from 'axios'
    import { useParams,BrowserRouter as Router, Route, Link, Routes } from "react-router-dom";
    import AnimauxListe from "./AnimauxListe";

    const Articles = ({animal}) => {
        const [error, setError] = useState(null);
        const [Animaux, setAnimaux] = useState([]);
        const { id } = useParams()
        useEffect(() => {
            axios
              .get(`http://localhost:1337/api/animaux/`+id)
              .then(({ data }) => setAnimaux(data))
              .catch((error) => setError(error))
          }, [id])

          if (error) {
            // Print errors if any
            return <div>An error occured: {error.message}</div>;
          }
          console.log(Animaux)
     return(
        <div>
          Id :   {Animaux.data.id}
          Nom : {Animaux.data.attributes.nom}
          Description : {Animaux.data.attributes.Description}
            {/* cet animal a pour id {id} */}
            {/* {Animaux.map(animal =>
        <div key={animal.id} className="card" >
              <span className="btn btn-primary">Voir {animal.attributes.nom}</span>
               </div>
         )}
         */}
            </div>
     )



    };

    export default Articles;
    Dans un premier temps, tout fonctionne parfaitement et mes informations s'affichent sans aucun problème. 
    Cependant, lorsque je réactualise , tout disparait et on me retourne un tableau vide. 
    Ce que j'ai du mal à comprendre c'est pourquoi ça fonctionne tout d'abord et ensuite non. 
    Voici le résultat quand tout fonctionne et celui lorsque je réactualise. A noter que si je met le code en commentaire et le décommente ça refonctionne puis, a la prochaine réactualisation, ça ne fonctionne plus.
    La première fois : 
    Après actualisation :
    Merci pour votre aide.

    -
    Edité par niakr 22 juin 2022 à 13:14:09

    • Partager sur Facebook
    • Partager sur Twitter
      22 juin 2022 à 14:45:04

      Bonjour,

      Le message qui suit est une réponse automatique activée par un membre de l'équipe. Les réponses automatiques leur permettent d'éviter d'avoir à répéter de nombreuses fois la même chose, ce qui leur fait gagner du temps et leur permet de s'occuper des sujets qui méritent plus d'attention.
      Nous sommes néanmoins ouverts et si vous avez une question ou une remarque, n'hésitez pas à contacter la personne en question par Message Privé.

      Pour plus d'informations, nous vous invitons à lire les règles générales du forum

      Merci de colorer votre code à l'aide du bouton Code

      Les forums d'Openclassrooms disposent d'une fonctionnalité permettant de colorer et mettre en forme les codes source afin de les rendre plus lisibles et faciles à manipuler par les intervenants. Pour cela, il faut utiliser le bouton Code de l'éditeur, choisir un des langages proposés et coller votre code dans la zone prévue. Si vous utilisez l'éditeur de messages en mode Markdown, il faut utiliser les balises <pre class="brush: jscript;">Votre code ici</pre>.

      Merci de modifier votre message d'origine en fonction.

      Liens conseillés

      • Partager sur Facebook
      • Partager sur Twitter

      Strapi et react , afficher UN element de la bdd

      × Après avoir cliqué sur "Répondre" vous serez invité à vous connecter pour que votre message soit publié.
      × Attention, ce sujet est très ancien. Le déterrer n'est pas forcément approprié. Nous te conseillons de créer un nouveau sujet pour poser ta question.
      • Editeur
      • Markdown