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 :

séléctionner l'id d'une balise ajoutée avec append


Sujet :

jQuery

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre très actif
    Homme Profil pro
    Inscrit en
    Février 2010
    Messages
    118
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 118
    Par défaut séléctionner l'id d'une balise ajoutée avec append
    mon problème c'est un problème de id :
    hello2 ne s'affiche jamais

    voila mon 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
    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
     
    <!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" dir="ltr">
    <head>
    	<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
     
    	<link rel="stylesheet" href="css/general.css" type="text/css" media="screen" />
     
     
    <script type="text/javascript" src="js/jquery-1.7.2.min.js"></script>
     
    <script type="text/javascript">
    $(document).ready(function(){
     
     $("#left-column .nav #li1project").on('click', function(){
    alert('hello1');
     $('#left-column .nav').prepend('<li id="limenu"><a HREF="" TARGET="article">menu principale</a></li>');
      $('#left-column .nav #li1project').remove();
      $('#left-column .nav #li2project').remove();
      $('#left-column .nav').append('<li id="li1text"><a HREF="" TARGET="article" >ajouter un texte</a></li>');
      $('#left-column .nav').append('<li id="li2text"><a class="ls" HREF="" TARGET="article">rechercher un texte</a></li>');
    });
     
     
     $("#left-column .nav #li1text").on('click', function(){
     
     alert('hello2');
     
     });
     
    });
    </script>
     
    </head>
    <body> 
     
    <div style="height: 100px;">
    </div>
    <div id="left-column">
     
                    <h3>Table d'administration</h3>
                    <ul class="nav">
                        <li id="li1project"><a HREF="creationProjet.php" TARGET="article">creer projet</a></li>
                        <li id="li2project"><a HREF="rechercheProjet.php" TARGET="article">rechercher un projet</a></li>
     
     
                    </ul>
                    <a href="#" class="link" >Link here</a>
                    <a href="#" class="link" >Link here</a>
     
    </div>
     
    </body> 
    </html>

  2. #2
    Membre expérimenté Avatar de eckerdecker
    Profil pro
    Inscrit en
    Décembre 2009
    Messages
    134
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Décembre 2009
    Messages : 134
    Par défaut
    Problème classique de délégation d'évènement : quand tu ajoutes ton handler à #li1text, il n'existe pas encore puisqu'il ne sera créé que lorsque tu cliqueras sur #li1project.

    Solution :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $("#left-column .nav").on('click', '#li1text', function(){
      alert('hello2');
    });
    Regardes bien la documentation du .on(), elle est certes longues car .on() rassemble ce qui était .bind(), .live(), .delegate() mais tout est là

  3. #3
    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 660
    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 660
    Billets dans le blog
    1
    Par défaut
    pas besoin de on ... la balise est appendé juste avant ... elle existe donc au moment de la declaration du click

    on sert à declarer le click pour les elements qui n'existent pas encore sur la page
    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 !

  4. #4
    Membre très actif
    Homme Profil pro
    Inscrit en
    Février 2010
    Messages
    118
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 118
    Par défaut
    donc c'est quoi la solution

  5. #5
    Membre très actif
    Homme Profil pro
    Inscrit en
    Février 2010
    Messages
    118
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 118
    Par défaut
    merci les développeurs
    la solution de eckerdecker marche bien .

  6. #6
    Membre expérimenté Avatar de eckerdecker
    Profil pro
    Inscrit en
    Décembre 2009
    Messages
    134
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Décembre 2009
    Messages : 134
    Par défaut
    Citation Envoyé par SpaceFrog Voir le message
    pas besoin de on ... la balise est appendé juste avant ... elle existe donc au moment de la declaration du click
    Hmm, non, son .on() est en dehors du premier handler et donc exécuté quand le #li1text n'existe pas dans le DOM.
    Citation Envoyé par SpaceFrog Voir le message
    on sert à declarer le click pour les elements qui n'existent pas encore sur la page
    Non plus, on est une méthode ajoutée en 1.7 qui en fonction des paramètres qui lui sont données fonctionne soit comme .bind(), soit comme .delegate() qui disparaissent en 1.8

  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 660
    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 660
    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
     
    $(function(){
    $("#foo").append('<li id="li1text"><a HREF="afficherTexte.php" TARGET="article" >ajouter un texte</a></li>');
    alert( $('#foo li:eq(0)').attr('id') )
    })
    </script>
    </head>
    <body>
    <ul id="foo">
    </ul>
    heu ??? là sans on ça marche bien
    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 !

  8. #8
    Membre expérimenté Avatar de eckerdecker
    Profil pro
    Inscrit en
    Décembre 2009
    Messages
    134
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Décembre 2009
    Messages : 134
    Par défaut
    Heu ouais mais ton exemple n'a rien de commun avec son problème ...

    Il déclare deux handlers click sur deux éléments différents, or il déclare le deuxième sur un élément qui ne sera créé que si le premier handler est executé. Donc quand le deuxième handler est déclaré son élément n'existe pas.

    Je pense que tu as mal regardé jusqu'où s’arrêtait le code du premier handler.

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

Discussions similaires

  1. éxecution d'une requête ajout avec VBA
    Par averooès dans le forum VBA Access
    Réponses: 16
    Dernier message: 06/02/2009, 17h22
  2. Ecrire dans une balise <td> avec VBS
    Par Scarface698 dans le forum VBScript
    Réponses: 8
    Dernier message: 26/05/2008, 13h20
  3. [RegEx] supprimer une balise html avec son contenu
    Par waldoun dans le forum Langage
    Réponses: 7
    Dernier message: 06/02/2008, 11h19
  4. mise en forme d'une cellule ajouter avec insertRow
    Par vacknov dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 31/07/2007, 08h33
  5. passer une requete ajout avec des enregitrement null
    Par LesLemmings dans le forum Requêtes et SQL.
    Réponses: 15
    Dernier message: 13/06/2006, 15h20

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