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 :

Désérialiser un objet avec méthode


Sujet :

JavaScript

  1. #1
    lvr
    lvr est déconnecté
    Membre extrêmement actif Avatar de lvr
    Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Avril 2006
    Messages
    909
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Avril 2006
    Messages : 909
    Points : 1 360
    Points
    1 360
    Par défaut Désérialiser un objet avec méthode
    Bonjour,

    Je souhaite créer des instances d'une classe sur base d'une string json contenant les attributs des objets à créer.
    Cette classe (et donc ses instances) doivent offrir un certain nombre de méthode (je viens du java donc sorry si la terminologie n'est pas parfaite).

    Voici comme je fais. Ca marche. Mais je trouve cela laborieux.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    page=JSON.parse(page_json_string);
    page=enrichPage(page);
     
    function enrichPage(page) {
        page.isDouble = function () {
            return (this.number.indexOf("-") > -1);
        };
        return page;
    }

    N'y a-t-il pas plus propre et de définir la classe Page et de l'instancier avec le json, comme ceci ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    PageClass = function (page_json_string) {     
        // ??????  
    }; 
    PageClass.prototype = { 
        isDouble:function() {
            return (this.number.indexOf("-") > -1);
        } 
    };
     
    var page=new PageClass(page_json_string);
    Je bloque sur la partie "// ??????" !!

  2. #2
    Expert confirmé
    Avatar de TiranusKBX
    Homme Profil pro
    Développeur C, C++, C#, Python, PHP, HTML, JS, Laravel, Vue.js
    Inscrit en
    Avril 2013
    Messages
    1 476
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur C, C++, C#, Python, PHP, HTML, JS, Laravel, Vue.js
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 1 476
    Points : 4 805
    Points
    4 805
    Billets dans le blog
    6
    Par défaut
    alors oui en javascript il n'y à pas de classe mais des prototypes
    du coup si j'ai bien compris ce que tu veut faire la multi-instanciation n'est pas possible
    Rien, je n'ai plus rien de pertinent à ajouter

  3. #3
    Expert éminent
    Avatar de sekaijin
    Homme Profil pro
    Urbaniste
    Inscrit en
    Juillet 2004
    Messages
    4 205
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Urbaniste
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 4 205
    Points : 9 127
    Points
    9 127
    Par défaut
    Json tout comme en java ne peux transporter que des données.

    je ne suis pas sur d'avoir tout compris mais
    normalement voici ce que l'on fait

    on défini un prototype (équivalent d'un constructeur java)
    ce prototype prend en paramètre ce que l'on veux

    libre à toi de lui passer un ou des objets.
    tu peux donc très bien lui passer une string.

    le corps du constructeur est totalement libre.
    tu peux donc appeler JSON.parse et faire ce que tu veux de l'objet obtenu.

    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
    PageClass = function (page_json_string) {     
      var data = JSON.parse(page_json_string);
      if (undefined == data.number) {
         // le fragment json ne contient pas le champs number
         this.number = 0;
      } else {
         this.number = data.number;
      }
    }; 
    PageClass.prototype = { 
        isDouble:function() {
            return (this.number.indexOf("-") > -1);
        } 
    };
     
    var page=new PageClass('{"number" : "-134"}');
    je ne comprends pas car c'est exactement la même chose que tu aurais fait an java avec un constructeur utilisant une Json String.


    un détail au passage je ne comprend pas la fonction. plus exactement this.number.indexOf("-") > -1soit ton json contient un membre number qui est un nombre {"number" : -134E-32}et le corps de ta fonction devrait être this.number > 0 (ou tout autre opération sur un nombre.) ou this.number.toString().indexOf("-") > -1 soit c'est une string mais alors le nom du membre est étrange.

    {"number" : -134E-32} number est un nombre.
    {"number" : "-134E-32"} number est une string.
    A+JYT

  4. #4
    Rédacteur/Modérateur

    Avatar de SylvainPV
    Profil pro
    Inscrit en
    Novembre 2012
    Messages
    3 375
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 3 375
    Points : 9 944
    Points
    9 944
    Par défaut
    Le passage String -> Object est assuré par JSON.parse. On ne peut pas le transformer directement en objet PageClass (note: les classes n'existent pas en JavaScript, un objet PageClass est un objet construit par la fonction constructeur PageClass). Mais tu peux appeler ton constructeur PageClass avec les données dans l'objet issu de JSON.parse :

    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
    var PageClass = function (data) {     
        this.number = data.number;
    }; 
    
    
    PageClass.prototype.isDouble = function() {
        return (this.number.indexOf("-") > -1);    
    };
    
    
    PageClass.prototype.toJSON = function() {
        return JSON.stringify(this);
    };
    
    
    PageClass.fromJSON = function(page_json_string) {
        return new PageClass(JSON.parse(page_json_string));
    };
    
    
    var page = PageClass.fromJSON(page_json_string); // on peut retrouver page_json_string avec page.toJSON();
    var page2 = new PageClass({ number: 2 });
    One Web to rule them all

  5. #5
    lvr
    lvr est déconnecté
    Membre extrêmement actif Avatar de lvr
    Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Avril 2006
    Messages
    909
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Avril 2006
    Messages : 909
    Points : 1 360
    Points
    1 360
    Par défaut
    Citation Envoyé par sekaijin Voir le message
    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
    PageClass = function (page_json_string) {     
      var data = JSON.parse(page_json_string);
      if (undefined == data.number) {
         // le fragment json ne contient pas le champs number
         this.number = 0;
      } else {
         this.number = data.number;
      }
    }; 
    PageClass.prototype = { 
        isDouble:function() {
            return (this.number.indexOf("-") > -1);
        } 
    };
     
    var page=new PageClass('{"number" : "-134"}');
    +1
    C'est ce que je veux. Si ce n'est qu'en Java tu ne dois pas passer par l'objet intermédiaire data dans lequel on désérialise le json.
    Java instancie ça directement convenablement. Et cette obligation de passer par un objet intermédiaire qui me turlupinait...

    Citation Envoyé par SylvainPV Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    PageClass.fromJSON = function(page_json_string) {
        return new PageClass(JSON.parse(page_json_string));
    };
    var page = PageClass.fromJSON(page_json_string); // on peut retrouver page_json_string avec page.toJSON();
    Et j'ai en plus maintenant une approche "factory" qui n'est pas pour me déplaire !!

    Je dis

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

Discussions similaires

  1. [eZ Publish Community Project 2012.3] relation d'objet avec méthode de selection "parcourir"
    Par stephanegib2 dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 2
    Dernier message: 21/06/2012, 16h28
  2. Réponses: 28
    Dernier message: 29/12/2011, 19h24
  3. [XStream] Désérialiser un objet avec une valeur par défaut
    Par djodjo dans le forum Format d'échange (XML, JSON...)
    Réponses: 0
    Dernier message: 21/04/2009, 13h47
  4. [Singleton] Différences avec méthodes statiques
    Par Franche dans le forum Design Patterns
    Réponses: 1
    Dernier message: 26/02/2003, 17h10
  5. A propos des modèles d'objet (avec sources)
    Par DevX dans le forum C++Builder
    Réponses: 14
    Dernier message: 01/12/2002, 12h22

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