JS fetch est vide, aucune donner retourner
Résolu
firpic
Messages postés
90
Date d'inscription
Statut
Membre
Dernière intervention
-
firpic Messages postés 90 Date d'inscription Statut Membre Dernière intervention -
firpic Messages postés 90 Date d'inscription Statut Membre Dernière intervention -
A voir également:
- JS fetch est vide, aucune donner retourner
- Retourner ecran pc - Guide
- Comment retourner une video - Guide
- Supprimer page word vide - Guide
- Caractere vide - Guide
- Coeur vide ✓ - Forum Réseaux sociaux
5 réponses
Bonjour,
Que donne ton console.log ?
Que donne ton console.log ?
firpic
Messages postés
90
Date d'inscription
Statut
Membre
Dernière intervention
1
voici le console.log :
Bonjour,
Il ne faut pas déclarer la constante results à l'intérieur d'accolades :
Il ne faut pas déclarer la constante results à l'intérieur d'accolades :
const res = await fetch("http://localhost/disc/user/user-list/"); const results = await res.json();
Oups j'ai parlé un peu vite, la syntaxe avec les accolades est correcte mais va dépendre de la réponse json.
Regarde la réponse de fetch dans l'onglet Réseau de ton navigateur pour voir et comparer le résultat json renvoyé avec les deux URLs (randomuser.me/... et localhost/...).
SInon, peux-tu nous montrer le code PHP qui génère la réponse json (ou un exemple simplifié) ?
Regarde la réponse de fetch dans l'onglet Réseau de ton navigateur pour voir et comparer le résultat json renvoyé avec les deux URLs (randomuser.me/... et localhost/...).
SInon, peux-tu nous montrer le code PHP qui génère la réponse json (ou un exemple simplifié) ?
Oui je peux te montrer le code PHP qui genere le json. Je préviens juste que le code que j'ai fais est archaïque mais je n'y arrivais pas autrement.
Et avec les accolades, j'ai aucun retour, la variable est vide alors que sans, j'ai un retour
voici le code php pour generer le json:
Et avec les accolades, j'ai aucun retour, la variable est vide alors que sans, j'ai un retour
voici le code php pour generer le json:
<?php require('../config.php'); $q = mysqli_query($conn, "SELECT username, icon FROM user"); $n = mysqli_num_rows($q); $nou = $n; $n=$n-1; $d=1; echo '{ '; echo '"numberOfUser":"'.$nou.'",'; echo '"user":['; while($row = mysqli_fetch_assoc($q)){ $arr = array("username"=>$row['username'], "icon"=>$row['icon']); echo json_encode($arr); if($d<=$n){ echo ','; } $d=$d+1; } echo ']}'; ?>
Ah oui.. ton json semble faut...
Essaye plutot
Essaye plutot
<?php require('../config.php'); $q = mysqli_query($conn, "SELECT username, icon FROM user"); $n = mysqli_num_rows($q); $nou = $n; $result = []; // on initialise un array vide qui contiendra le résultat à renvoyer en json $result['numberOfUser'] = $nou; $result['user'] = []; // on initialise un array vide qui contiendra la liste des users while($row = mysqli_fetch_assoc($q)){ $result['user'][] = array("username"=>$row['username'], "icon"=>$row['icon']); } echo json_encode($result); // on retourne le résultat au format JSON ?>
Tu te compliques la tâche en essayant de créer une partie du json à la main.
C'est plus simple de construire ta réponse à l'aide de tableau et/ou objet en PHP, puis d'utiliser un seul json_encode à la fin de ton script, avec le bon Content-Type dans l'entête http :
Puisque le fichier ne contient que du code PHP, il n'est pas nécessaire d'ajouter la balise fermante "?>" à la fin du fichier.
Coté js, un exemple très simple pour récupérer le json :
ou en déclarant les variables avec l'utilisation des accolades :
C'est plus simple de construire ta réponse à l'aide de tableau et/ou objet en PHP, puis d'utiliser un seul json_encode à la fin de ton script, avec le bon Content-Type dans l'entête http :
<?php require '../config.php'; $resultUsers = mysqli_query($conn, 'SELECT username, icon FROM user'); if ($resultUsers === false) { $data = ['error' => 'Erreur sql']; } else { $data = [ 'numberOfUsers' => mysqli_num_rows($resultUsers), 'users' => mysqli_fetch_all($resultUsers, MYSQLI_ASSOC) ]; } header('Content-Type: application/json; charset=utf-8'); echo json_encode($data);
Puisque le fichier ne contient que du code PHP, il n'est pas nécessaire d'ajouter la balise fermante "?>" à la fin du fichier.
Coté js, un exemple très simple pour récupérer le json :
async function getData(){ const response = await fetch('http://localhost/json.php'); const json = await response.json(); console.log('Total : ' + json.numberOfUsers); json.users.forEach((user) => { console.log(user.username); }); }
ou en déclarant les variables avec l'utilisation des accolades :
async function getData(){ const response = await fetch('json.php'); const { numberOfUsers, users } = await response.json(); console.log('Total : ' + numberOfUsers); users.forEach((user) => { console.log(user.username); }); }
J'ai cette erreur avec ce code :
Et le resultat renvoyer en json par php est :
<code>
{
numberOfUser: 3,
user: [
{username: "admin",icon: "img/user-icon/user-lightgreen.png"},
{username: "clem",icon: "img/user-icon/user-red.png"},
{username: "ethan...",icon: "img/user-icon/user-blue.png"}
]
}
/code>
async function getData(){ const response = await fetch('http://localhost/json.php'); const json = await response.json(); console.log('Total : ' + json.numberOfUsers); json.users.forEach((user) => { console.log(user.username); }); }
Et le resultat renvoyer en json par php est :
<code>
{
numberOfUser: 3,
user: [
{username: "admin",icon: "img/user-icon/user-lightgreen.png"},
{username: "clem",icon: "img/user-icon/user-red.png"},
{username: "ethan...",icon: "img/user-icon/user-blue.png"}
]
}
/code>
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Bonjour,
Tu fais
Alors que ton json contient
Tu fais
json.users.
Alors que ton json contient
user: [
Mtn j'ai cette erreur la :
Et voici le nouveau code js:
Total : 3
search.js:16 Uncaught (in promise) TypeError: Cannot read properties of undefined (reading 'username')
at search.js:16:31
at Array.forEach (<anonymous>)
at search_ (search.js:15:15)
Et voici le nouveau code js:
async function search_(){ const response = await fetch('http://localhost/disc/user/user-list/'); const json = await response.json(); console.log('Total : ' + json.numberOfUser); json.user.forEach((user) => { console.log(user.user.username); }); }