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

JavaScript Discussion :

[POO] parcourir un objet json avec une boucle for in


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    38
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Juin 2006
    Messages : 38
    Par défaut [POO] parcourir un objet json avec une boucle for in
    je rencontre un problème très bizarre et j'espere que quelqu'un pourra m'aider.
    J'ai un tableau associatif en php que j'encode en json.
    Dans le code j'affecte cet objet à une variable:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    listIcon = eval('(' + <?=$listMapIcons; ?> + ')');
    puis je tente de parcourir le tableau de la manière suivante:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    for(key in listIcon){
    //Traitement
    }
    et la une chose très bizarre apparait: sous Firefox aucun problème alors que sous ie cela me génère une erreur et le script s'arrète.

    une idée ?
    D'avance merci

  2. #2
    Expert confirmé
    Avatar de le_chomeur
    Profil pro
    Développeur informatique
    Inscrit en
    Février 2006
    Messages
    3 653
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 3 653
    Par défaut
    dès qu'on aura le code html généré

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    38
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Juin 2006
    Messages : 38
    Par défaut
    En effet ça va aider

    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
    listIcon = {"vente":"\/public\/img\/gg-icon\/dog.png","donnation":"\/public\/img\/gg-icon\/dog.png"};
    tblIcons =  new Array();
     
    for(key in listIcon){
    	var icon = new GIcon();
    	icon.image = listIcon[key];
     
    	icon.iconSize = new GSize(16, 16);
    	icon.shadowSize = new GSize(16, 16);
    	icon.iconAnchor = new GPoint(26, 23);
    	icon.infoWindowAnchor = new GPoint(16, 0);
     
    	tblIcons[key] = icon;
     
     }
    Pour info je l'utilise pour GG map et d'avoir un tableau de marqueurs avec des icons spéficiques.

  4. #4
    Rédacteur
    Avatar de marcha
    Homme Profil pro
    Développeur Web
    Inscrit en
    Décembre 2003
    Messages
    1 571
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Décembre 2003
    Messages : 1 571
    Par défaut
    Salut,

    Tu pourrais essayer d'isoler la partie du code qui pose problème
    en faisant quelques tests, par exemple en commentant des parties
    comme ceci:

    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
     
    listIcon = {"vente":"\/public\/img\/gg-icon\/dog.png","donnation":"\/public\/img\/gg-icon\/dog.png"};
    tblIcons =  new Array();
     
    for(key in listIcon){
           alert(listIcon[key]);
    /*	var icon = new GIcon();
    	icon.image = listIcon[key];
     
    	icon.iconSize = new GSize(16, 16);
    	icon.shadowSize = new GSize(16, 16);
    	icon.iconAnchor = new GPoint(26, 23);
    	icon.infoWindowAnchor = new GPoint(16, 0);
     
    	tblIcons[key] = icon;
     */
     }

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    38
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Juin 2006
    Messages : 38
    Par défaut
    sous FF cela m'affiche bien les bonnes données sans aucun problème.

    Mais sous ie une erreur apparait avant de rentrer dans la boucle.
    Et voila ce mon debugger JS sous ie me dit:
    il me dit: Cette objet ne gère pas cette propriété ou cette méthode.

  6. #6
    Expert confirmé
    Avatar de le_chomeur
    Profil pro
    Développeur informatique
    Inscrit en
    Février 2006
    Messages
    3 653
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 3 653
    Par défaut
    bizare , quel est el message d'erreur ?

  7. #7
    Expert confirmé
    Avatar de le_chomeur
    Profil pro
    Développeur informatique
    Inscrit en
    Février 2006
    Messages
    3 653
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 3 653
    Par défaut
    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
     
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
    <html>
    	<head>
    		<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
    		<title>Untitled Document</title>
    	</head>
    	<body>
    		<script type="text/javascript">
    		var mon_objet = {"vente":"\/public\/img\/gg-icon\/dog.png","donnation":"\/public\/img\/gg-icon\/dog.png"};
    		var strinUrl = "";
    		for (var name in mon_objet) {
    		strinUrl += "-" + name + "=" + encodeURI(mon_objet[name]);
    		}
    		alert(strinUrl);
    	</script>
    	</body>
    </html>
    marche nickel

  8. #8
    Membre averti
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    38
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Juin 2006
    Messages : 38
    Par défaut



  9. #9
    Expert confirmé
    Avatar de le_chomeur
    Profil pro
    Développeur informatique
    Inscrit en
    Février 2006
    Messages
    3 653
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 3 653
    Par défaut
    pour moi l'erreur vient d'ailleur , test mon exemple sous ie et firefox ...

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

Discussions similaires

  1. Structure while avec une boucle for en test
    Par le_voisin dans le forum C++
    Réponses: 9
    Dernier message: 09/09/2006, 19h16
  2. Problème avec une boucle for
    Par cisse18 dans le forum Général JavaScript
    Réponses: 20
    Dernier message: 29/03/2006, 16h50
  3. Incrémentation dynamique d'un textbox avec une boucle for
    Par Etanne dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 06/03/2006, 15h17
  4. Comment parcourir un fichier texte avec une boucle ?
    Par kikica dans le forum Langage
    Réponses: 2
    Dernier message: 15/11/2005, 17h13
  5. : remplir des zones de texte avec une boucle For
    Par Haro_GSD dans le forum Access
    Réponses: 3
    Dernier message: 20/09/2005, 21h23

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