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 :

Supprimer un DIV dynamiquement


Sujet :

JavaScript

Vue hybride

SPACHFR Supprimer un DIV dynamiquement 26/05/2009, 16h19
SpaceFrog Soit tu le crées à chaque... 26/05/2009, 16h36
SPACHFR Merci pour ces réponses, ... 26/05/2009, 16h54
SpaceFrog un seul div suffit ... il... 26/05/2009, 16h56
SPACHFR En fait il s'agit... 27/05/2009, 09h35
bigboomshakala display > none visibility >... 26/05/2009, 18h24
Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de SPACHFR
    Profil pro
    Paaaaaa
    Inscrit en
    Février 2004
    Messages
    557
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Paaaaaa

    Informations forums :
    Inscription : Février 2004
    Messages : 557
    Par défaut Supprimer un DIV dynamiquement
    Bonjour,

    J'essaie de mettre au point un équivalent de tooltip pour un textarea.
    J'arrive à créer le DIV et à l'afficher, mais mon problème est de le supprimer.

    Existe t'il la méthode inverse à "document.createElement" ?
    Mon ami Google est très discret sur le sujet.....

    Voici un exemple du code que j' utilise pour mon test.
    Le div créé est en fond rouge (pas beau mais j'expérimente).

    Il y a 2 fonctions :

    ChangeArea : change la taille du "textarea"
    ShowComment : qui affiche le contenue du "textarea"

    C'est le Div créé par ShowComment que je souhaiterai supprimer

    Merci

    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
     
    <html>
    <head>
    <script>
    function ChangeArea(ObjId,val) {
     var Obj = document.getElementById(ObjId);
     if (val==0) {
    	Obj.style.height = "60px";
     } else if (val==1) {
    	Obj.style.height = "20px";
     }
    }
    function ShowComment(ObjId,ev) {
     if(!document.getElementById('CCpt')) {
    	var Obj = document.getElementById(ObjId);
    	Xpos = ev.clientX;
    	Ypos = ev.clientY;
    	var CCpt = document.createElement('div');
    	CCpt.id ='ccpt';
    	CCpt.style.position ="absolute";
    	CCpt.style.top = Ypos;
    	CCpt.style.left = Xpos;
    	CCpt.style.width = "200px";
    	CCpt.style.height = "200px";
    	CCpt.style.backgroundColor ="red";
    	CCpt.innerHTML = Obj.value;
    	CCpt.style.visibility ="visible";
    	document.body.appendChild(CCpt);
     }
    }
    </script>
    </head>
    <body>
    <div id="tt">
    <input type="text" id="inpt1" value="ligne1">
    <TEXTAREA id="txt1" style="height:20px" COLS="50" onfocus="ChangeArea(this.id,0);" onblur="ChangeArea(this.id,1);" onmousemove="ShowComment(this.id,event)";>
    TEST
    </textarea>
    </div>
    </body>
    </html>

  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 658
    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 658
    Billets dans le blog
    1
    Par défaut
    Soit tu le crées à chaque fois et du coup tu fais un removeCHild,
    soit tu ne le crées qu'une fois et tu changes son display
    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 éclairé Avatar de SPACHFR
    Profil pro
    Paaaaaa
    Inscrit en
    Février 2004
    Messages
    557
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Paaaaaa

    Informations forums :
    Inscription : Février 2004
    Messages : 557
    Par défaut
    Merci pour ces réponses,

    J'ai bien pensé à passer le "display" en "hidden", mais dans ma page définitive, je vais avoir n lignes ayant un "textarea" (créées dynamiquement sur action de l'utilisateur). Donc j'ai pas trop envie de trainer des DIV pour rien.

    Je vais regarder removeCHild ça me semble bien.....

    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 658
    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 658
    Billets dans le blog
    1
    Par défaut
    un seul div suffit ...
    il suffit d'en changer le contenu et de le positionner ou tu veux ...
    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 !

  5. #5
    Membre éclairé Avatar de SPACHFR
    Profil pro
    Paaaaaa
    Inscrit en
    Février 2004
    Messages
    557
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Paaaaaa

    Informations forums :
    Inscription : Février 2004
    Messages : 557
    Par défaut
    Citation Envoyé par SpaceFrog Voir le message
    un seul div suffit ...
    il suffit d'en changer le contenu et de le positionner ou tu veux ...
    En fait il s'agit "d'événements utilisateur que j'envoie lorsque l'ensemble des saisie sont finies vers le serveur via un requête XMLHttpRequest.

    L'ensemble des événements sont affichés au fur et à mesure de leurs déclarations. La zone textarea est en fait des commentaires utilisateurs.
    Le but final et obtenir l'équivalent d'un tooltips lors du passage sur le textarea et de l'afficher sous la position courante de la sourie.
    Je ne suis pas loin du résultat reste à supprimer le div puis de gérer correctement l'affichage.

  6. #6
    Membre éclairé Avatar de SPACHFR
    Profil pro
    Paaaaaa
    Inscrit en
    Février 2004
    Messages
    557
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Paaaaaa

    Informations forums :
    Inscription : Février 2004
    Messages : 557
    Par défaut
    Je ne m'en sort pas avec le removeChild, j'ai du louper un truc.
    Lors de l'événement 'onMouseOut', j'ai l'erreur suivante :

    Ligne 38 Le type ne correspond pas

    C'est dans ma fonction HideComment mais je ne comprend pas pourquoi...

    Pourriez vous m'indiquer mon erreur

    Merci

    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
     
    <html>
    <head>
    <script>
    function ChangeArea(ObjId,val) {
     var Obj = document.getElementById(ObjId);
     if(document.getElementById('ccpt')) {
        var CCpt = document.getElementById('ccpt');
    	document.body.removeChild(CCpt);
     
     }
     if (val==0) {
    	Obj.style.height = "60px";
     } else if (val==1) {
    	Obj.style.height = "20px";
     }
    }
    function ShowComment(ObjId,ev) {
      Xpos = ev.clientX;
      Ypos = ev.clientY;
     if(!document.getElementById('ccpt')) {
    	var Obj = document.getElementById(ObjId);
    	var CCpt = document.createElement('div');
    	CCpt.id ='ccpt';
    	CCpt.style.position ="absolute";
    	CCpt.style.top = Ypos;
    	CCpt.style.left = Xpos;
    	CCpt.style.width = "200px";
    	CCpt.style.height = "200px";
    	CCpt.style.backgroundColor ="#FFFF99";
    	CCpt.style.border ="solid #DDDDDD";
    	CCpt.innerHTML = Obj.value;
    	CCpt.style.visibility ="visible";
    	document.body.appendChild(CCpt);
     }
    }
    function HideComment(ObjId) {
    	if(document.getElementById('ccpt')) {
    		document.body.removeChild('ccpt');
    	}
    }
    </script>
    </head>
    <body>
    <div id="tt">
    <input type="text" id="inpt1" value="ligne1">
    TEST<TEXTAREA id="txt1" style="height:20px" COLS="50" onfocus="ChangeArea(this.id,0);" onblur="ChangeArea(this.id,1);" onMouseOver="ShowComment(this.id,event);" onMouseOut="HideComment(this.id);">
     
    </textarea>
    </div>
    </body>
    </html>

  7. #7
    Rédacteur
    Avatar de bigboomshakala
    Homme Profil pro
    Consultant Web .NET
    Inscrit en
    Avril 2004
    Messages
    2 077
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Consultant Web .NET
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2004
    Messages : 2 077
    Par défaut
    Citation Envoyé par SPACHFR Voir le message
    Merci pour ces réponses,

    J'ai bien pensé à passer le "display" en "hidden", mais dans ma page définitive, je vais avoir n lignes ayant un "textarea" (créées dynamiquement sur action de l'utilisateur). Donc j'ai pas trop envie de trainer des DIV pour rien.

    Je vais regarder removeCHild ça me semble bien.....

    MERCI
    display > none
    visibility > hidden

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

Discussions similaires

  1. [C#] Supprimer un combox dynamique
    Par lykim1982 dans le forum C#
    Réponses: 4
    Dernier message: 09/02/2007, 16h37
  2. [AJAX] Div dynamique AJAX. Sous IE, les images ne s'affichent pas
    Par N3odyme dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 10/12/2006, 20h56
  3. [ok]remplir des div dynamiquement?
    Par manutudescends dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 28/08/2006, 16h24
  4. Ajouter/Supprimer un select dynamiquement
    Par n@n¤u dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 22/06/2006, 10h22
  5. div dynamique
    Par Invité(e) dans le forum Balisage (X)HTML et validation W3C
    Réponses: 11
    Dernier message: 21/10/2005, 22h50

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