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

jQuery Discussion :

Récupération valeurs dans un tableau JSON


Sujet :

jQuery

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2011
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Décembre 2011
    Messages : 17
    Points : 14
    Points
    14
    Par défaut Récupération valeurs dans un tableau JSON
    Bonjour,

    mon titre est un peu flou, et pour cause, je ne comprend pas forcément tout ce que je suis en train de faire.
    je vais tenter de vous expliquer la situation :
    Un Web Service a été créé pour renvoyer un flux JSON sur une page http.
    Lorsque je vais sur cette page voici ce que je récupère :
    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
    get_my_leagues(
    {"result":"1",
     "leagues":[
    {
     "i":"https:\/\/www.monsite.com\/imagine\/league\/uploads\/ligues\/4fcceb6b6c4e9.jpg",
     "ln":"Le sport est un jeu",
     "lid":526,
     "n":"262",
     "c0":90,
     "p0":0,
     "dp0":0,
     "c1":81,
     "p1":0,
     "dp1":0}
    ]  })
    Mon objectif est de traiter ces informations et de pouvoir les afficher dans une appli mobile.
    Pour ce faire, je crée une fonction js que j'appelle get_my_leagues()
    Voici son contenu actuel :
    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
     
    function get_my_leagues()
    {
    	$('.loader').fadeIn('slow');
    	emailOrUsername = readCookie("login");
    	password = readCookie("password");
    	if (emailOrUsername == null)
    		emailOrUsername = g_login;
    	if (password == null)
    		password = g_password;
    	//Ici on crée un JSON pour passer des paramètres au serveur lors de l'appel Ajax.	
    	var data = jQuery.parseJSON('{"emailOrUsername":"' + emailOrUsername + '","password":"' + password + '","code_version":"' + code_version + '"}');
    	$.ajax({
    		type : "POST",
    		//Ici on indique à l'appli mobile où elle doit récupérer le JSON.
    		url : BaseUrl() + "/appmobile/get_my_leagues",
    		dataType : 'jsonp',
    		data : (data),
    		cache : false,
    		crossDomain : true,
    		timeout : 10000,
    		success : function(data) {
    			var dataresponse = eval(data); // objet javascript dont on peut exploiter les valeurs retournée par le WebService
     
    			if (dataresponse.result == 1) { //On a bien récupéré la liste des ligues
     
    				var array_leagues = dataresponse.leagues;
    				//Cette variable est un tableau contenant une liste de ligue.
    				$('#leagues').html(JSON.stringify(array_leagues));
    				var ligue = $('#ligue'); //on récupere la balise ligue
    				ligue.html(""); //on vide la balise
    				ligue_html = "";
    				ligue_html += "<tbody>";
                                    for (var i in leagues)
    				{
    					ligue_html += ligue[i];
    				}
     
    			}
    }
    Ici, vous pouvez voir le léger début du fichier ligue.html que j'essaye de mettre en place pour récupérer les informations:
    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
     
    <script>
    		$(document).ready(function() {
    			current_page = "ligue";
    		    //Système de navigation asynchrone
    		    $("a").unbind("click");
    		    $("a").bind("click", function(){
    		        $.get($(this).attr('href'), function(data){
    		                $("#page").html(data);
    		        });
    		        return false;
    		    });
    		    get_my_leagues(); //on fait appel a la fonction get_my_leagues
    		});
        </script>
     
    	<div id="header">
    		<a href="main.html" id="home"></a>
    		Ligue <!-- <span id="gameweek_name"></span> -->
    	</div>
    	<div id="content2">
    	<span id="leagues" style="display: none;"></span>
    			<ul id="ligue"></ul>
    	</div>
    Je ne sais pas si j'ai donné toutes les informations ou pas, ma compréhension de tout cela est un peu vague.. Pourriez-vous m'éclairer svp ?

  2. #2
    Rédacteur

    Avatar de danielhagnoul
    Homme Profil pro
    Étudiant perpétuel
    Inscrit en
    Février 2009
    Messages
    6 389
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 73
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant perpétuel
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2009
    Messages : 6 389
    Points : 22 933
    Points
    22 933
    Billets dans le blog
    125
    Par défaut
    Bonsoir

    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
    var jqXHR = $.getJSON( BaseUrl() + "/appmobile/get_my_leagues", { 
    	"emailOrUsername" : emailOrUsername,
    	"password" : password,
    	"code_version" : code_version
    });
     
    jqXHR.done( function( data, textStatus, jqXHR ){
    	// succès de la transaction, on doit traiter le contenu de data
    	//console.log( data, textStatus, jqXHR );
     
    	/*
    	 * Récupération du premier objet dans l'array "leagues".
    	 */
    	var obj0InLeagues = data.leagues[ 0 ];
     
    	/*
    	 * lid ?
    	 */
    	console.log( obj0InLeagues.lid );
    });
     
    jqXHR.fail( function( jqXHR, textStatus, errorThrown ){
    	// échec de la transaction, gérer la catastrophe
    	console.log( jqXHR, textStatus, errorThrown );
     
    });

    Blog

    Sans l'analyse et la conception, la programmation est l'art d'ajouter des bogues à un fichier texte vide.
    (Louis Srygley : Without requirements or design, programming is the art of adding bugs to an empty text file.)

  3. #3
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Daniel, il s'agit d'une requête de type JSONP, c'est pourquoi la réponse contient la fonction de rappel (get_my_leagues(...).

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $.getJSON( BaseUrl() + "/appmobile/get_my_leagues?get_my_leagues=?", { 
    	"emailOrUsername" : emailOrUsername,
    	"password" : password,
    	"code_version" : code_version
    });
    suffit donc
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

Discussions similaires

  1. Mauvaise récupération de valeurs dans un tableau
    Par bourbour dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 01/02/2015, 14h02
  2. [AC-2010] Expression régulières et récupération de valeur dans un tableau
    Par Thugann dans le forum VBA Access
    Réponses: 0
    Dernier message: 30/06/2014, 09h27
  3. Récupérer une valeur dans un tableau de tableau de JSON
    Par ecnerrolf dans le forum Format d'échange (XML, JSON...)
    Réponses: 2
    Dernier message: 27/06/2014, 10h03
  4. [MySQL] récupération de valeurs dans un tableau
    Par cboulie dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 30/11/2010, 17h07
  5. Décaler des valeurs dans un tableau
    Par sh2003 dans le forum Langage
    Réponses: 6
    Dernier message: 20/03/2004, 16h01

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