CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

[Javascript] Problème promise avec commande fetch()

Ass2Trefle
Ass2Trefle
Niveau 70
14 janvier 2023 à 18:56:18

Voilà, je fais fasse à un mur depuis tout à l"heure et je n'arrive même pas à comprendre le problème.

aiAnswer(topic, aiMode)
.then(function(text) {

          console.log(text.choices[0].text);
          textarea.value = text.choices[0].text;

})

function aiAnswer(text, aiMode) { 

        if (aiMode) {

            const init = {

                method : 'POST',
                headers : {
                    'Authorization' : 'Bearer ' + apiKey,
                    'Content-Type' : 'application/json',
                },
                body : JSON.stringify({

                    model : 'text-ada-001',
                    prompt : text,
                    max_tokens : 100,
                    temperature : 0,

                }),

            };

            return fetch('https://api.openai.com/v1/completions', init)
            .then(res => res.json())
            .then(data => console.log(data))
            .catch(err => console.log(err))

        }

}

Suis-je à coté de la plaque vis à vis du synchronisme ? https://image.noelshack.com/fichiers/2018/29/6/1532128784-risitas33.png

Tothemoune
Tothemoune
Niveau 26
15 janvier 2023 à 12:22:01

Le problème c'est ton deuxième hook then()

Si tu fais return fetch().then(res => res.json()).catch(), ton code correspond à un return fetch().then(res => { return res.json() })

Par contre si tu ajoute un autre .then(), tu vas retourner la valeur renvoyée par ce second hook, en l'occurrence console.log() qui renvoie undefined

Ass2Trefle
Ass2Trefle
Niveau 70
15 janvier 2023 à 18:18:27

Le 15 janvier 2023 à 12:22:01 :
Le problème c'est ton deuxième hook then()

Si tu fais return fetch().then(res => res.json()).catch(), ton code correspond à un return fetch().then(res => { return res.json() })

Par contre si tu ajoute un autre .then(), tu vas retourner la valeur renvoyée par ce second hook, en l'occurrence console.log() qui renvoie undefined

Merci pour cette réponse, je pense avoir compris le problème.

Tothemoune
Tothemoune
Niveau 26
15 janvier 2023 à 19:07:31

Le 15 janvier 2023 à 18:18:27 :

Le 15 janvier 2023 à 12:22:01 :
Le problème c'est ton deuxième hook then()

Si tu fais return fetch().then(res => res.json()).catch(), ton code correspond à un return fetch().then(res => { return res.json() })

Par contre si tu ajoute un autre .then(), tu vas retourner la valeur renvoyée par ce second hook, en l'occurrence console.log() qui renvoie undefined

Merci pour cette réponse, je pense avoir compris le problème.

Y'a pas de quoi

Si tu veux reproduire le comportement attendu dans ton code du coup, return fetch().then(res => { console.log(res.json()); return res.json() })

poor2rich
poor2rich
Niveau 8
16 janvier 2023 à 00:23:49

Le 15 janvier 2023 à 12:22:01 :
Le problème c'est ton deuxième hook then()

Si tu fais return fetch().then(res => res.json()).catch(), ton code correspond à un return fetch().then(res => { return res.json() })

Par contre si tu ajoute un autre .then(), tu vas retourner la valeur renvoyée par ce second hook, en l'occurrence console.log() qui renvoie undefined

Non ça va juste retourner une Promise. Le code est bon c'est du code classique. Tu dis pas si t'as une erreur ou si il se passe rien.

Tothemoune
Tothemoune
Niveau 26
16 janvier 2023 à 00:40:30

Le 16 janvier 2023 à 00:23:49 :

Le 15 janvier 2023 à 12:22:01 :
Le problème c'est ton deuxième hook then()

Si tu fais return fetch().then(res => res.json()).catch(), ton code correspond à un return fetch().then(res => { return res.json() })

Par contre si tu ajoute un autre .then(), tu vas retourner la valeur renvoyée par ce second hook, en l'occurrence console.log() qui renvoie undefined

Non ça va juste retourner une Promise. Le code est bon c'est du code classique. Tu dis pas si t'as une erreur ou si il se passe rien.

Non
Ça va retourner la valeur retournée par le deuxième then(), soit la valeur retournée par console.log(), soit undefined

Et c'est pas une opinion j'ai testé pour être sûr

Ass2Trefle
Ass2Trefle
Niveau 70
16 janvier 2023 à 00:54:53

Ne vous battez pas :noel: , j'ai reussi à résoudre le problème avec la première réponse :fete:

Merci encore. :merci:

Tothemoune
Tothemoune
Niveau 26
16 janvier 2023 à 00:59:19

Le 16 janvier 2023 à 00:54:53 :
Ne vous battez pas :noel: , j'ai reussi à résoudre le problème avec la première réponse :fete:

Merci encore. :merci:

Tant mieux :-)
Hésite pas à reposter si t'as d'autres bugs

poor2rich
poor2rich
Niveau 8
16 janvier 2023 à 12:42:48

Je pensais que le but de la function c'était juste d'afficher le JSON pas de le renvoyer😊

Sous forums
  • Aide à l'achat Mac
  • Création de sites web
  • Internet
  • Macintosh
  • Création de Jeux
  • Linux
  • Programmation
  • Steam Deck
  • Hardware
La vidéo du moment