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 :

Deep copy JS


Sujet :

jQuery

  1. #1
    Membre confirmé
    Inscrit en
    Mai 2011
    Messages
    62
    Détails du profil
    Informations forums :
    Inscription : Mai 2011
    Messages : 62
    Par défaut Deep copy JS
    Bonjour à vous,

    Je recherche a cloner un element( sans référence et donc en deep copy d'après mes recherches sur le net) le problème c'est que ca ne marche pas comme je le veux... Petit exemple:

    Voici l'exemple de structure de mon objet que je veux copier:

    desGens = {
    20125 : { nom: "dupont", prenom: "Nicolas", livres[
    0:{nom: "le petit poucet", auteur:"Charles Perrault"}
    1:{nom: "nom2", auteur:"auteur2"}
    ]
    }
    20126 : { nom: "Bertrand", prenom: "Xavier", livres[
    0:{nom: "nom1", auteur:"nom2"}
    1:{nom: "nom2", auteur:"auteur2"}
    ]
    }
    Je l'ai résumé au plus simple.
    Quand je fais

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    copy_unGens= jQuery.extend(true, {}, lesGens[20126]);
    console.log(copy_unGens);
    // Object {nom: "Bertrand"}
    Je n'ai que le premier attribut.

    Merci à vous.

  2. #2
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 198
    Par défaut
    Bonjour,
    • en 1 il te faut écrire un objet JSON conforme ce qui est visiblement loin d'être le cas dans ton exemple:
    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
    var desGens = {
      '20125': {
        'nom': 'dupont',
        'prenom': 'Nicolas',
        'livres': [
          {
            '0': {
              'nom': 'le petit poucet',
              'auteur': 'Charles Perrault'
            },
            '1': {
              'nom': 'nom2',
              'auteur': 'auteur2'
            }
          }
        ]
      },
      '20126': {
        'nom': 'Bertrand',
        'prenom': 'Xavier',
        'livres': [
          {
            '0': {
              'nom': 'nom1',
              'auteur': 'nom2'
            },
            '1': {
              'nom': 'nom2',
              'auteur': 'auteur2'
            }
          }
        ]
      }
    }
    nota: les quottes sur les clés ne sont pas obligatoire, mais j'aime bien.

    • en 2 il te faut utiliser les variables que tu initialise, mais je pense que c'est une faute de frappe, lesGens[20126] au lieu de desGens[20126].

    A part ces points cela devrait fonctionner.

  3. #3
    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 : 74
    Localisation : Belgique

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

    Informations forums :
    Inscription : Février 2009
    Messages : 6 389
    Billets dans le blog
    125
    Par défaut
    @NoSmoking : pour un JSON valide, on doit utiliser le " pas le '.

    Lorsque vous écrivez du JSON, prenez le temps et l'espace (indentation) nécessaires. Sinon...

    Il y a une foule d'erreurs : oubli de ":", oubli de "," et utilisation d'un array anonyme "[]" au lieu d'un objet anonyme "{}" !

    Code javascript : 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
    let desGens = {
      "20125" : {
        "nom" : "dupont",
        "prenom" : "Nicolas",
        "livres" : {
          "0" : {
            "nom" : "le petit poucet",
            "auteur" : "Charles Perrault"
          },
          "1" : {
            "nom" : "nom2",
            "auteur" : "auteur2"
          }
        }
      },
      "20126" : {
        "nom" : "Bertrand",
        "prenom" : "Xavier",
        "livres" : {
          "0" : {
            "nom" : "nom1",
            "auteur" : "nom2"
          },
          "1" : {
            "nom" : "nom2",
            "auteur" : "auteur2"
          }
        }
      }
    };
     
    let desGens20126Clone = $.extend( true, {}, desGens[ "20126" ] );
     
    console.log( desGens20126Clone );
     
    // Object {nom: "Bertrand", prenom: "Xavier", livres: Object}

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

  4. #4
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 198
    Par défaut
    Citation Envoyé par danielhagnoul
    @NoSmoking : pour un JSON valide, on doit utiliser le " pas le '.
    Daniel, je suis bien d'accord avec toi, je n'ai pas parlé d'un JSON valide, au sens de la norme, mais conforme au sens de javascript, le sens du message était de signaler les manques comme tu l'a rappelé.

    Concernant l’utilisation des quottes ou des guillemets, j'utilise les guillemets pour le HTML et les quottes pour les langages, javascript, PHP..., et comme les (mauvaises) habitudes ont la vie dure, on a du mal à changer

  5. #5
    Membre confirmé
    Inscrit en
    Mai 2011
    Messages
    62
    Détails du profil
    Informations forums :
    Inscription : Mai 2011
    Messages : 62
    Par défaut
    Merci pour votre retour en effet l'objet étant assez complexe je me suis emmelé les pinceaux !
    Correction faite, cela fonctionne

    Merci

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

Discussions similaires

  1. [Débutant] Deep copy non serializable
    Par taspai dans le forum C#
    Réponses: 12
    Dernier message: 04/02/2016, 00h22
  2. Deep copy d'un tableau
    Par rusol dans le forum C++
    Réponses: 2
    Dernier message: 15/04/2014, 18h49
  3. Deep Copy d'objets similaires
    Par Emmanuel Lecoester dans le forum C#
    Réponses: 3
    Dernier message: 08/03/2010, 10h38
  4. Copie de fichier
    Par Bjorn dans le forum C
    Réponses: 4
    Dernier message: 11/06/2002, 15h23
  5. Peux t'on créer une copie locale de l'objet partagé?
    Par Anonymous dans le forum CORBA
    Réponses: 8
    Dernier message: 16/04/2002, 16h20

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