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 :

parser un json


Sujet :

jQuery

  1. #1
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Juillet 2006
    Messages
    147
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2006
    Messages : 147
    Points : 109
    Points
    109
    Par défaut parser un json
    Bonjour,

    je débute avec jquery, je n'arrive pas à obtenir tous les CategoryName d'un json avec mon jquery:
    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
     
    [
        {
            "CategoryID": 1,
            "CategoryName": "Beverages",
            "Description": "Soft drinks, coffees, teas, beers, and ales",
            "Picture": {
                "Length": 10746
            }
        },
        {
            "CategoryID": 2,
            "CategoryName": "Condiments",
            "Description": "Sweet and savory sauces, relishes, spreads, and seasonings",
            "Picture": {
                "Length": 10746
            }
        },
        {
            "CategoryID": 3,
            "CategoryName": "Confections",
            "Description": "Desserts, candies, and sweet breads",
            "Picture": {
                "Length": 10746
            }
        }
    ]
    Et voici mon jquery.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    $(window).ready(function() {
                $.ajax({
                    type: "POST",
                    url: "/Project/WebServiceCategories.asmx/GetCategories",
                    data: "{}",
                    contentType: "application/json; charset=utf-8",
                    dataType: "json",
                    success: function(msg) {
                        $.each(msg, function(key, value){
                            alert(value);
                        }) 
                    }
                })
            })
    si je fais value.CategoryName dans le alert, ca m'affiche undefined.


    Quelqu'un a t-il une solution à m'apporter ?

    merci d'avance.

  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
    $.each(json, function(i,item) {
        alert("Element = " + i + " : " + item.CategoryID + ", " + item.CategoryName + '\n' + item.Description + '\n' + item.Picture.Length);
    });

    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
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Juillet 2006
    Messages
    147
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2006
    Messages : 147
    Points : 109
    Points
    109
    Par défaut
    Citation Envoyé par danielhagnoul Voir le message
    Bonsoir.

    $.each(json, function(i,item) {
    alert("Element = " + i + " : " + item.CategoryID + ", " + item.CategoryName + '\n' + item.Description + '\n' + item.Picture.Length);
    });
    c'est undefined qui est retourné pour toutes les valeurs.

  4. #4
    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.

    Pour moi cela fonctionne parfaitement, 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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
     
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr">
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <title>Document sans nom</title>
        <script type="text/javascript" src="jquery-1.3.2.min.js"></script>
        <script type="text/javascript">
            $(document).ready(function() {
                var elClone = $("#conteneur").clone(true);
     
                $.getJSON("category.js", function(json) {
                    $(elClone).empty();
     
                    $.each(json, function(i,item) {
                        $("<p>Element = " + i + " : " + item.CategoryID + ", " + item.CategoryName + ", " + item.Description + ", " + item.Picture.Length + "</p>").appendTo(elClone);
                    });
                });
     
                $("#conteneur").replaceWith(elClone);
            });
        </script>
    </head>
    <body>
        <div id="conteneur">
            <p>
                Désolé, le code JSON n'est pas disponible !
            </p>
            <p>
                Veuillez avoir l'obligeance de signaler cette erreur au <a href='mailto:moi@ici.com'>Webmestre</a>. Merci !
            </p>
        </div>
    </body>
    </html>

    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.)

  5. #5
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Juillet 2006
    Messages
    147
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2006
    Messages : 147
    Points : 109
    Points
    109
    Par défaut
    effectivement ca fonctionne votre code.

    Je viens de remarquer que le problème venait d'autre part.

    si je fais un alert de ma variable value. J'obtiens le json que j'avais mis en haut.

    Par contre si je regarde dans firebug, dans l'onglet Response de mon webservice, j'obtiens un json avec pleins d'anti slash et un "d" devant. Comme le montre le json en bas. Pourtant le content type est bien indiqué text/json dans firebug.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    {"d":"[{\"CategoryID\":1,\"CategoryName\":\"Beverages\",\"Description\":\"Soft drinks, coffees, teas
    , beers, and ales\",\"Picture\":{\"Length\":10746}},{\"CategoryID\":2,\"CategoryName\":\"Condiments\"
    ,\"Description\":\"Sweet and savory sauces, relishes, spreads, and seasonings\",\"Picture\":{\"Length
    \":10746}},{\"CategoryID\":3,\"CategoryName\":\"Confections\",\"Description\":\"Desserts, candies, and
     sweet breads\",\"Picture\":{\"Length\":10746}},{\"CategoryID\":4,\"CategoryName\":\"Dairy Products\"
    ,\"Description\":\"Cheeses\",\"Picture\":{\"Length\":10746}},{\"CategoryID\":5,\"CategoryName\":\"Grains
    /Cereals\",\"Description\":\"Breads, crackers, pasta, and cereal\",\"Picture\":{\"Length\":10746}},{
    \"CategoryID\":6,\"CategoryName\":\"Meat/Poultry\",\"Description\":\"Prepared meats\",\"Picture\":{\"Length
    \":10746}},{\"CategoryID\":7,\"CategoryName\":\"Produce\",\"Description\":\"Dried fruit and bean curd
    \",\"Picture\":{\"Length\":10746}},{\"CategoryID\":8,\"CategoryName\":\"Seafood\",\"Description\":\"Seaweed
     and fish\",\"Picture\":{\"Length\":10746}}]"}

    Je pense que c'est au niveau du C# qui a mal serialiser mon objet.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    JavaScriptSerializer js = new JavaScriptSerializer();
            return (js.Serialize(monObjetASerialiser));
    Merci pour ton aide.

Discussions similaires

  1. Parser le json avec la resultat de ma recherche
    Par moezBH dans le forum Services Web
    Réponses: 2
    Dernier message: 26/09/2011, 16h16
  2. Parser un JSON avec des variables avec des "-" et des ":"
    Par Quentin33 dans le forum Windows Phone
    Réponses: 2
    Dernier message: 22/05/2011, 01h04
  3. Parser du json
    Par nox73 dans le forum Langage
    Réponses: 4
    Dernier message: 19/05/2011, 19h52
  4. Parser page JSON en PHP
    Par tonymx15 dans le forum Langage
    Réponses: 4
    Dernier message: 08/04/2011, 00h55
  5. [Prototype] Parser du JSON aprés une requête Ajax
    Par Gregory.M dans le forum Bibliothèques & Frameworks
    Réponses: 18
    Dernier message: 16/06/2010, 10h21

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