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 - append - impossible de le selectionner


Sujet :

jQuery

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2008
    Messages : 16
    Par défaut jquery - append - impossible de le selectionner
    Bonjour,

    mon problème est assez simple, mais je ne trouve pas de solution malgré mes nombreuses recherches sur le web.

    En fait lorsque je crée un élément avec .append .html .text etc. Les éléments créé ne sont pas accessibles depuis mes sélecteurs.

    Ce qui est assez logique étant donné qu'ils sont créé après le chargement de la page et donc de mes sélecteurs.

    Connaissez-vous une astuce me permettant de palier à ce problème?

    Merci =)

    Voilà des jours que je cherche sans succès

  2. #2
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    Tu pourrais donner un exemple ?
    Parce que
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $('#toto').append('<div id="tata">Nouveau contenu</div>');
    alert($('#tata'));
    fonctionne très bien
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2008
    Messages : 16
    Par défaut exemple
    Oui bien sur, voilà un exemple

    On crée l'élément quand on clique sur création_element

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    $('#creation_element').click (function () {
    	$("#conteneur").append ("<p class='test'>Test</p>")
    });
    Une fois créé, j'aimerais que cet élément soit lui-même cliquable

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    $('.test').click (function () {
           alert ('ok');
    });
    Code complet

    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
     
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>test</title>
    <script type="text/javascript" src="js/jquery-ui/js/jquery-1.5.1.min.js"></script>
    <script type="text/javascript">
    	$(document).ready(function () {
    		$('#creation_element').click (function () {
    			$("#conteneur").append ("<p class='test'>Test</p>")
    		});
     
     
    	$('.test').click (function () {
    		   alert ('ok');
    	});
     
    	});
    </script>
    </head>
     
    <body>
    	<p id="creation_element">creation element</p>
     
        <div id="conteneur">
        </div>
    </body>
    </html>

  4. #4
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    Là c'est pas le append qui pose problème mais la logique globale...
    Si tu affectes le clic sur un élément qui n'existe pas, ben c'est sûr que ça marche moins bien
    Il y a plusieurs solutions pour parer à cela.
    * Définir le clic après l'insertion
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $('#creation_element').click (function () {
        $("#conteneur").append ("<p class='test'>Test</p>");
        $('.test').click (function () {
           alert ('ok');
        });
    });
    * Utiliser la méthode live()
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $('.test').live('click', function(){...};
    * Utiliser la méthode delegate() (plus recommandée que la précédente)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $('#conteneur').delegate('.test', 'click', function(){...});
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2008
    Messages : 16
    Par défaut
    super, je ne connaissais pas ces methode.

    Un grand merci

  6. #6
    Rédacteur

    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    494
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2007
    Messages : 494
    Par défaut
    Bovino j'ai une tite question : pourquoi delegate est plus recommandée que .live ?

  7. #7
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    Il y a des raisons assez compliquées dues au fonctionnement interne de cette méthode, mais sinon, elle attache l'événement à la racine du document, puis vérifie si la balise qui a reçu l'événement correspond à celui indiqué. Or si l'événement est stoppé (return false, stopPropagation(), ...) avant, il ne sera jamais reçu. Delegate() attache l'événement à la balise qui a appelé la méthode, c'est préférable.

    Mais ce n'est qu'un seul des aspects (par exemple, tu ne peux pas utiliser live() à partir d'une méthode de parcours du DOM).
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  8. #8
    Rédacteur

    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    494
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2007
    Messages : 494
    Par défaut
    Citation Envoyé par Bovino Voir le message
    Il y a des raisons assez compliquées dues au fonctionnement interne de cette méthode, mais sinon, elle attache l'événement à la racine du document, puis vérifie si la balise qui a reçu l'événement correspond à celui indiqué. Or si l'événement est stoppé (return false, stopPropagation(), ...) avant, il ne sera jamais reçu. Delegate() attache l'événement à la balise qui a appelé la méthode, c'est préférable.

    Mais ce n'est qu'un seul des aspects (par exemple, tu ne peux pas utiliser live() à partir d'une méthode de parcours du DOM).
    Ok je te remercie pour ces éclaircissement je n'étais pas allé aussi loin dans l'usage de ces deux fonctions

Discussions similaires

  1. Jquery append mathjax
    Par bm dans le forum jQuery
    Réponses: 0
    Dernier message: 25/02/2014, 21h18
  2. [JQuery Mobile] Impossible de zoomer
    Par PP(Team) dans le forum Mobiles
    Réponses: 2
    Dernier message: 02/11/2012, 23h40
  3. Réponses: 14
    Dernier message: 09/10/2011, 20h45
  4. [jQuery UI] Impossible d'initialiser un draggable()
    Par Arnaud F. dans le forum jQuery
    Réponses: 3
    Dernier message: 18/08/2010, 09h47
  5. jquery append dans un table sous ie6
    Par boo64 dans le forum jQuery
    Réponses: 9
    Dernier message: 21/07/2009, 21h41

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