IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

React Discussion :

Récupérer les données d'une API


Sujet :

React

  1. #1
    Membre régulier
    Femme Profil pro
    Développeur Web
    Inscrit en
    Octobre 2010
    Messages
    414
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Octobre 2010
    Messages : 414
    Points : 111
    Points
    111
    Par défaut Récupérer les données d'une API
    Bonjour
    Je n'arrive pas à récupérer les données de l'API
    Voici mon code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
     
    onSearch = async (dpt, type) => {
      if(dpt && type){
        try {
          let response = await fetch('https://etablissements-publics.api.gouv.fr/v1/organismes/${dpt}/${type}')
          let data = await response.json();
          this.setState({
            data: data.features,
            error: ''
          })
        } catch(e){
          this.setState({ erro : "Erreur lors de la recherche"}) 
        }
      }else{
         this.setState({ error: "Merci de choisir un département et un établissement"})
      }
    }
    Pourtant que je vais sur ce lien : https://etablissements-publics.api.g...nismes/76/cpam

    J'obtiens bien les données json.
    Formatrice - Web développeuse - WebMarketing - Recrutement
    Site O'ClockWeb : http://oclockweb.cvflashjob.com/
    Mon Facebook : https://www.facebook.com/minkoueobame

  2. #2
    Membre expérimenté
    Avatar de gwyohm
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2007
    Messages
    925
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Octobre 2007
    Messages : 925
    Points : 1 333
    Points
    1 333
    Par défaut
    salut, mais t'as quoi comme erreur ?
    on ne dit pas "ça ne marche pas" on dit "je suis incapable de faire fonctionner correctement les outils mis à ma disposition"
    Pas de question technique par MP

  3. #3
    Membre régulier
    Femme Profil pro
    Développeur Web
    Inscrit en
    Octobre 2010
    Messages
    414
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Octobre 2010
    Messages : 414
    Points : 111
    Points
    111
    Par défaut
    Désolée j'ai oublié de mettre l'erreur:
    La voici:
    Access to fetch at 'https://etablissements-publics.api.gouv.fr/v1/organismes/$%7Bdpt%7D/$%7Btype%7D' from origin 'http://localhost:3002' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource. If an opaque response serves your needs, set the request's mode to 'no-cors' to fetch the resource with CORS disabled.
    App.js:20 GET https://etablissements-publics.api.gouv.fr/v1/organismes/$%7Bdpt%7D/$%7Btype%7D net::ERR_FAILED
    Formatrice - Web développeuse - WebMarketing - Recrutement
    Site O'ClockWeb : http://oclockweb.cvflashjob.com/
    Mon Facebook : https://www.facebook.com/minkoueobame

  4. #4
    Membre expérimenté
    Avatar de gwyohm
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2007
    Messages
    925
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Octobre 2007
    Messages : 925
    Points : 1 333
    Points
    1 333
    Par défaut
    alors, problème 1 : tu a mis des ' et non des `
    du coup l'URL est pas bonne.
    problème 2 : cors. ce service n'est pas ouvert en cross domaines.
    à noter que /v3/departements/76/cpam lui est ouvert... il te convient celui là ?
    on ne dit pas "ça ne marche pas" on dit "je suis incapable de faire fonctionner correctement les outils mis à ma disposition"
    Pas de question technique par MP

  5. #5
    Membre régulier
    Femme Profil pro
    Développeur Web
    Inscrit en
    Octobre 2010
    Messages
    414
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Octobre 2010
    Messages : 414
    Points : 111
    Points
    111
    Par défaut Le clic de mon bouton ne fonctionne pas
    Bonjour
    Je n'arrive pas à afficher les données codées en dur quand je clique sur le bouton
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
     <Button primary onClick={() =>this.props.onSearch(this.state.dpt, this.state.type)}>Lancer la recherche</Button>

    Voici les données en dur d'un établissement:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    import React from 'react';
    import { Card } from 'semantic-ui-react';
     
     
    const Etablissement = () => {
        return (
            <Card>
                <Card.Content>
                    <Card.Header>Nom d'établissement</Card.Header>
                    <Card.Meta>Téléphone: 01 23 45 67 89</Card.Meta>
                    <Card.Meta>Email: abc@def.com</Card.Meta>
                </Card.Content>
            </Card>
        )
    }
     
     
    export default Etablissement;
    Voici le composant où se trouve mon bouton "<Button primary..."
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    import React, {Component} from 'react';
    import { Button, Select } from 'semantic-ui-react';
    import './recherche.css';
     
     
    class Recherche extends Component {
     
        state = {
             dpt : '',
             type : ''
        }
     
     
        onDptChange = (e, data) => { 
        this.setState({dpt : data.value})
        }
     
     
        onTypeChange = (e, data) => {  
            this.setState({type : data.value})
            }
     
     
     
            render(){
            const optionDpt = [
                {value: "76", key: "76", text: "Seine-Maritime"},
                {value: "27", key: "27", text: "Eure"},
                {value: "14", key: "14", text: "Calvados"},
                {value: "75", key: "75", text: "Paris"},
            ];
     
     
            const optionsType = [
                { value: "cpam", key:"cpam", text: "Caisse primaire d’assurance maladie (CPAM)"},
                { value: "cci", key:"cci", text: "Chambre de commerce et d’industrie (CCI)"},
                { value: "crous", key:"crous", text: "CROUS et ses antennes"}
            ]
            return(
                <div className="recherche">
                    <Select placeholder="Choisissez un département" onChange={this.onDptChange} options={optionDpt} value={this.state.dpt} />
                    <Select placeholder="Choisissez une administration" onChange={this.onTypeChange} options={optionsType} value={this.state.type} />
                    <Button primary onClick={() => this.props.onSearch(this.state.dpt, this.state.type)}>Lancer la recherche</Button>
                    <Button secondary onClick={this.props.onEmpty}>Vider la recherche</Button>
                </div>
            )
        }
    }
     
     
    export default Recherche;
    Et voici mon fichier App.js qui affiche le resultat :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
     
    import React, { Component } from 'react';
    import Recherche from './components/Recherche';
    import Etablissement from './components/Etablissement';
    import { Message, Card } from 'semantic-ui-react';
     
     
    import './App.css';
     
     
    class App extends Component {
     
     
      state = {
        data: [],
        error: ''
      }
     
     
    onEmpty = () => {
      this.setState({ data: [], error: ''})
    }
    onSearch = async (dpt, type) => {
      if(dpt && type){
        try {
          let response = await fetch('https://etablissements-publics.api.gouv.fr/v3/departements/${dpt}/${type}')
          let data = await response.json();
          this.setState({
            data: data.features,
            error: ''
          })
        } catch(e){
          this.setState({ erro : "Erreur lors de la recherche"}) 
        }
      }else{
         this.setState({ error: "Merci de choisir un département et un établissement"})
      }
    }
     
     
    renderResults = () => {
      return this.state.data.map((etablissement) => {
        return <Etablissement key={etablissement.properties.id} properties={etablissement.properties} />
      })
    }
      render() {
        return (
          <div className="App">
            <h1>Annuaire des Administrations en Pays de la Loire</h1>
            <Recherche onSearch={this.onSearch} onEmpty={this.onEmpty} />
            { this.state.error ? <Message warning>{this.state.error}</Message> : undefined} 
            {this.state.data ? 
            <Card.Group>
              { this.renderResults() }
            </Card.Group>
            : undefined }
          </div>
        );
      }
    }
     
     
    export default App;
    Formatrice - Web développeuse - WebMarketing - Recrutement
    Site O'ClockWeb : http://oclockweb.cvflashjob.com/
    Mon Facebook : https://www.facebook.com/minkoueobame

  6. #6
    Membre régulier
    Femme Profil pro
    Développeur Web
    Inscrit en
    Octobre 2010
    Messages
    414
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Octobre 2010
    Messages : 414
    Points : 111
    Points
    111
    Par défaut
    Oui effectivement ça marche suite à tes conseils, merci la solution est comme ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
      let response = await fetch(`https://etablissements-publics.api.gouv.fr/v3/departements/${dpt}/${type}`)
    Formatrice - Web développeuse - WebMarketing - Recrutement
    Site O'ClockWeb : http://oclockweb.cvflashjob.com/
    Mon Facebook : https://www.facebook.com/minkoueobame

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Récupérer les données d'une API météo
    Par nass985 dans le forum Langage
    Réponses: 0
    Dernier message: 30/04/2020, 16h01
  2. Quel language pour récupérer de manière continue les données d'une api
    Par Scottbass dans le forum Général Conception Web
    Réponses: 2
    Dernier message: 11/03/2019, 09h10
  3. Réponses: 15
    Dernier message: 20/06/2006, 10h29
  4. Récupérer les données après une recherche
    Par cdumas dans le forum Access
    Réponses: 7
    Dernier message: 04/05/2006, 12h09
  5. Récupérer les données d'une iframe
    Par juli1 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 4
    Dernier message: 09/02/2005, 22h53

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo