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 :

jQuery - récupération d'id


Sujet :

jQuery

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif
    Avatar de Mell
    Femme Profil pro
    Développeuse Front-end
    Inscrit en
    Janvier 2011
    Messages
    107
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 34
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeuse Front-end
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2011
    Messages : 107
    Par défaut jQuery - récupération d'id
    Bonjour,
    Ca fait plusieurs jours que je suis sur le même problème.
    Voila je suis en train de faire un livre d'or, un peu plus complet qu'à l'habituel.
    En effet, à chaque message posté dans ce livre d'or, on peut y répondre, comme dans un forum.
    Donc voila comment ça se passe,
    J'ai un message avec une flèche au bout. Quand je clique sur une flèche un contenu s'ouvre avec dedans les réponses s'il y en a et un petit formulaire à remplir pour y mettre sa propre réponse.
    Une classe contient l'image de ma flèche pour qu'elle se répète sauf que qd je clique sur une flèche, ça ouvre tous les contenus. Ce qui est logique vu qu'ils ont tous la même classe.
    De ce fait j'ai essayé de jouer avec un id unique mais le problème survient quand je veux le récupérer.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    var id = $('.mont_desc').attr('id');
    Mon code récupère tjs le même id, c'est à dire le premier qui est en rapport avec ma classe. Du coup je ne peux pas appliquer mon jQuery à l'id voulu.
    La classe mont_desc contient ma flèche et la classe plus_moins a le contenu que je veux faire apparaître.
    Je sais j'ai pas été chercher bien loin le nom de mes classes, mais bon pour le moment je veux juste faire fonctionner mon code, je changerais les noms plus tard.

    Voici mon code php/html
    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
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    </span><br /><span class='livre_cont'><div class='barre_livre'>Message de <a target='_blank' href=mailto:'bouletos@bipbip.com'>trgsdrhth</a> le 24/04/2012<div class='mont_desc' id='result1'></div></div><div class='cont_livre'>z"rgfts</div><div class='plus_moins'>                            <div class="form_reponse">
     
                                    <form action="index.php?params=livre_or&cat_id=1&id=4" method="POST">
     
                                        <input type="hidden" name="id" value="14" />
     
                                        <div class="form_reponse_part1">
     
                                            <label for="auteur">Auteur :</label>
     
                                            <input type="text" id="auteur" name="auteur" value=""/><br />
     
     
     
                                            <label for="email">E-mail :</label>
     
                                            <input type="email" id="email" name="email" value=""/><br />
     
                                        </div>
     
                                        <div class="form_reponse_part2">
     
                                            <label for="message">Message :</label>
     
                                            <textarea id="message" name="message" cols="40" rows="5" ></textarea><br />
     
                                        </div>
     
                                        <input class="livre_reponse" type="submit" name="livre_reponse" value="Répondre">
     
                                        <div></div>
     
                                        <br clear="both" />
     
                                    </form>
     
                                </div>
     
                            </div>
     
                           </span><br /><span class='livre_cont'><div class='barre_livre'>Message de <a target='_blank' href=mailto:'bouletos@bipbip.com'>ergtsrtg</a> le 24/04/2012<div class='mont_desc' id='result2'></div></div><div class='cont_livre'>qzefqf</div><div class='plus_moins'>                            <div class="form_reponse">
     
                                    <form action="index.php?params=livre_or&cat_id=1&id=4" method="POST">
     
                                        <input type="hidden" name="id" value="15" />
     
                                        <div class="form_reponse_part1">
     
                                            <label for="auteur">Auteur :</label>
     
                                            <input type="text" id="auteur" name="auteur" value=""/><br />
     
     
     
                                            <label for="email">E-mail :</label>
     
                                            <input type="email" id="email" name="email" value=""/><br />
     
                                        </div>
     
                                        <div class="form_reponse_part2">
     
                                            <label for="message">Message :</label>
     
                                            <textarea id="message" name="message" cols="40" rows="5" ></textarea><br />
     
                                        </div>
     
                                        <input class="livre_reponse" type="submit" name="livre_reponse" value="Répondre">
     
                                        <div></div>
     
                                        <br clear="both" />
     
                                    </form>
     
                                </div>
     
                            </div>
    et voici mon code jQuery pour l'animation
    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
    <script type="text/javascript">
                            $(document).ready(function(){
                                $(".plus_moins").hide();
     
                                $(".mont_desc").click(function(){
                                    var more = $('.plus_moins');
                                    var id = $('.mont_desc').attr('id');
                                    if (more.is(':hidden')) {
                                        $(".mont_desc").animate({'opacity' : '0'},200, function() {
                                            $(this).css({'background-image' : 'url(images/plus.png)'})
                                                .animate({'opacity' : '1'},200);
                                        });
                                        more.show('slow');
                                    }else{
                                        $(".mont_desc").animate({'opacity' : '0'},200, function() {
                                            $(this).css({'background-image' : 'url(images/moins.png)'})
                                                .animate({'opacity' : '1'},200);
                                        });
                                        more.hide('slow');
                                    } 
                                });
                            });
                    </script>
    Merci d'avance de votre aide.
    Amicalement,
    Mell

  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 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    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 659
    Billets dans le blog
    1
    Par défaut
    le code serveur ne nous est pas utile, au contraire ...

    Montre nous plutot le code source généré !

    Sinon
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    var id = $('.mont_desc').attr('id');
    tu selectionnes par une classe ... ça retourne une collection

    essaye
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    var id = $('.mont_desc:eq(0)').attr('id');
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    var id = $('.mont_desc')[0].attr('id');
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  3. #3
    Membre actif
    Avatar de Mell
    Femme Profil pro
    Développeuse Front-end
    Inscrit en
    Janvier 2011
    Messages
    107
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 34
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeuse Front-end
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2011
    Messages : 107
    Par défaut
    Merci j'arrive à récupérer l'id grâce à

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    var id = $('.mont_desc:eq(0)').attr('id')
    J'avais déjà essayé l'autre manière mais elle ne fonctionnait pas.
    Maintenant il faut que je trouve le moyen d'activer mon jQuery seulement pour cet id.

    Mais quand je met

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    id.animate({'opacity' : '0'},200, function() {
     $(this).css({'background-image' : 'url(images/plus.png)'})
       .animate({'opacity' : '1'},200);
                                        });
    C'est pas possible, ça ne fonctionne qu'avec une classe.

    J'ai aussi testé en faisant ça aussi (bien entendu j'ai modifié la place de mon id dans mon html)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    ...
    var id = $('.plus_moins:eq('+i+')').attr('id');
    if (id.is(':hidden')) 
    ...
    Mais c'est pareil, je ne peux pas utiliser ma fonction is() avec l'id.


    J'ai remodifié mon code dans mon premier message, je n'ai mis que les deux premiers messages de mon livre d'or, vu que le reste c'est la même chose.

  4. #4
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    la récupération de l'id n'est pas nécessaire :
    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
    $(document).ready(function(){
    	$(".plus_moins").hide();
     
    	$(".mont_desc").click(function(){
    		var more = $(this).parent().parent().find('.plus_moins'); // cherche le div '.plus_moins' qui suit celui cliqué
     
    		if (more.is(':hidden')) {
    			$(this).animate({'opacity' : '0'},200, function() {
    				$(this).css({'background-image' : 'url(images/plus.png)'})
    					.animate({'opacity' : '1'},200);
    			});
    			more.show('slow');
    		}else{
    			$(this).animate({'opacity' : '0'},200, function() {
    				$(this).css({'background-image' : 'url(images/moins.png)'})
    					.animate({'opacity' : '1'},200);
    			});
    			more.hide('slow');
    		} 
    	});
    });

  5. #5
    Membre actif
    Avatar de Mell
    Femme Profil pro
    Développeuse Front-end
    Inscrit en
    Janvier 2011
    Messages
    107
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 34
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeuse Front-end
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2011
    Messages : 107
    Par défaut
    Oh merci ça marche !

  6. #6
    Membre Expert

    Homme Profil pro
    Ingénieur Hospitalier
    Inscrit en
    Juillet 2004
    Messages
    993
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur Hospitalier
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 993
    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
     
    $('.mont_desc').each(function(i){
      $('.mont_desc:eq('+i+')').animate({'opacity' : '0'},200, function() {
        $(this).css({'background-image' : 'url(images/plus.png)'})
       .animate({'opacity' : '1'},200);
                                        });
    });

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
     
    $('.mont_desc').each(function(i){
      if ($('.mont_desc:eq('+i+')').css("overflow").is(':hidden')){
           //you code here
      }
    });
    Essaye ça.

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

Discussions similaires

  1. Jquery récupération attr au click
    Par matini dans le forum jQuery
    Réponses: 11
    Dernier message: 06/10/2011, 11h53
  2. récupération de variable dans jquery
    Par vladock dans le forum jQuery
    Réponses: 9
    Dernier message: 29/06/2011, 12h23
  3. Récupération liste déroulante jquery
    Par apidou dans le forum Langage
    Réponses: 1
    Dernier message: 07/09/2010, 13h31
  4. Réponses: 2
    Dernier message: 21/11/2008, 10h32
  5. Réponses: 15
    Dernier message: 07/07/2008, 09h21

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