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 :

Créer dynamiquement un array d'objets lors du parcours d'un autre array d'objets


Sujet :

jQuery

  1. #1
    Membre confirmé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juillet 2006
    Messages
    985
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juillet 2006
    Messages : 985
    Points : 460
    Points
    460
    Par défaut Créer dynamiquement un array d'objets lors du parcours d'un autre array d'objets
    Bonjour,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    var obj = [
        {nom: 'John', age: 18, sexe: 'Homme'}, 
        {nom: 'Samuel', age: 20, sexe: 'Homme'}, 
        {nom: 'Berthe', age: 33, sexe: 'Femme'}, 
        {nom: 'Peter', age: 33, sexe: 'Homme'}, 
        {nom: 'Marcelle', age: 20, sexe: 'Femme'}
    ];
    var femmes = [], hommes = [];
    $.each(obj, function(i, item) { 
    	if(item.sexe == 'Homme') //remplir var hommes avec tous les hommes de obj
    	else //remplir var femmes avec tous les femmes de obj
    });
    Comment remplir dynamiquement var hommes et var femmes ?

    Merci d'avance...

  2. #2
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 640
    Points : 66 663
    Points
    66 663
    Billets dans le blog
    1
    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
    $(function(){
     var obj = [
        {nom: 'John', age: 18, sexe: 'Homme'}, 
    		{nom: 'Samuel', age: 20, sexe: 'Homme'}, 
    		{nom: 'Peter', age: 33, sexe: 'Homme'}, 
    		{nom: 'Berthe', age: 33, sexe: 'Homme'}, 
    		{nom: 'Marcelle', age: 20, sexe: 'Femme'}
    ];
    var femmes = [], hommes = [];
    $.each(obj, function(i, item) { 
    	if( item.sexe == 'Homme')  { hommes.push(  $(this) )  }
    	else { femmes.push( $(this) )  }
     
     })
     
    })

  3. #3
    Membre confirmé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juillet 2006
    Messages
    985
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juillet 2006
    Messages : 985
    Points : 460
    Points
    460
    Par défaut
    Merci.

  4. #4
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 640
    Points : 66 663
    Points
    66 663
    Billets dans le blog
    1
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    switch ( item.sexe){
      case:  'Homme' :  hommes.push(  $(this) ) ;
                                  break;
     default:	 femmes.push( $(this) ) ; 
    }

  5. #5
    Membre confirmé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juillet 2006
    Messages
    985
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juillet 2006
    Messages : 985
    Points : 460
    Points
    460
    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
     
    var obj = [
        {nom: 'John', age: 18, sexe: 'Homme'}, 
        {nom: 'Samuel', age: 20, sexe: 'Homme'}, 
        {nom: 'Peter', age: 33, sexe: 'Homme'}, 
        {nom: 'Berthe', age: 33, sexe: 'Homme'}, 
        {nom: 'Marcelle', age: 20, sexe: 'Femme'}
    ], femmes = [], hommes = [];
     
    $(function(){
    $.each(obj, function(i, item) { 
    	switch ( item.sexe){
                case:  'Homme' : hommes.push(  $(this) );                           
    	    break;
     	    default: femmes.push( $(this) ); 
            }
    });
    });

  6. #6
    Invité
    Invité(e)
    Par défaut
    un switch pour deux cas, ca picote les yeux. Je vois absolument pas l'intérêt si ce n'est le prétexte que dans le futur yaura les sexe indéterminés.

    Genre, d'abord les hommes,
    ensuite les indéterminés,
    ET si jamais on a un sexe qui n'est "même" pas indéterminé, alors c'est une femme!

    Sinon, on peut également yaller ainsi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    var all={'Homme':[],'Femme':[]};
    $.each//{
     all[item.sexe].push(item);
    }
    mais un if/else c'est très bien.

  7. #7
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 640
    Points : 66 663
    Points
    66 663
    Billets dans le blog
    1
    Par défaut
    pour conserver des array distincts:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Femmes =new Array();
     Hommes = new Array();
    Sexes= []
    Sexes['Homme']=Hommes
    Sexes['Femme']=Femmes
    $.each(obj, function(i, item) { ;
    Sexes[item.sexe].push($(this))

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

Discussions similaires

  1. Réponses: 5
    Dernier message: 27/08/2012, 11h19
  2. Utiliser un objet créer dynamiquement
    Par Clydopathe dans le forum VB.NET
    Réponses: 6
    Dernier message: 04/06/2009, 17h18
  3. Créer dynamiquement des objets Java
    Par choko83 dans le forum Débuter avec Java
    Réponses: 15
    Dernier message: 02/05/2008, 14h53
  4. Exploration Objets créer dynamiquement
    Par BATiViR dans le forum C#
    Réponses: 9
    Dernier message: 30/01/2008, 13h58
  5. Réponses: 1
    Dernier message: 17/04/2007, 14h43

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