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 :

Un truc compliqué (créer un a avec href dynamiquement)


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti Avatar de sansamis
    Inscrit en
    Janvier 2007
    Messages
    71
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 71
    Par défaut Un truc compliqué (créer un a avec href dynamiquement)
    Si vous avez suivi mes différents problèmes d'aujourd'hui tant mieu, sinon c'est pas grave...

    Voila le truc:

    J'ai une page qui affiche juste "Salut Roger !", cette phrase se trouvant entre <body> et </body>.

    Ce que je veux, c'est un script JS à ajouter entre <head> et </head> uniquement et sans rien ajouter d'autre, qui ferait que, lorsque je passe le curseur sur le mot "Roger", une decription du Roger (ici "Roger est gentil") s'affiche au niveau du curseur.

    J'ai donc fait ca:

    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
    window.onload = pbo;
     
    function pbo()
    {
    var code = document.body.innerHTML;
    code = code.replace(/Roger/g, '<a href="#" onmouseover="javascript: over_Roger();">Roger</a>');
    document.body.innerHTML = code;
    }
     
    function over_Roger();
    {
    document.getElementById("desc").style.left = event.x+document.body.scrollLeft;
    document.getElementById("desc").style.top = event.y+document.body.scrollTop;
    document.getElementById("desc").innerHTML = "Roger est gentil";
    desc.style.display = "";
    }
     
    document.write('<div id="desc" style="position: absolute; display: none;"></div>');
    En revanche si j'enlève ca:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    function over_Roger();
    {
    document.getElementById("desc").style.left = event.x+document.body.scrollLeft;
    document.getElementById("desc").style.top = event.y+document.body.scrollTop;
    document.getElementById("desc").innerHTML = "Roger est gentil";
    desc.style.display = "";
    }
    "Roger" est bien remplacé par "<a href="#" onmouseover="javascript: over_Roger();">Roger</a>".

    Ma question: pourquoi l'ajout de la fonction "over_Roger();" fait que rien ne marche plus ?

    Que faire ?

    Merci 'avance...

  2. #2
    Expert confirmé
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 660
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 660
    Par défaut
    bonjour,

    deux questions :
    - es-tu sûr que le div id="desc" existe (place un alert dans ta fonction over_Roger et regarde ce que retourne document.getElementById() ) ? La méthode write() pour ajouter un élément dans ta page n'est vraiment pas ce qu'il y a de mieux.

    - Compte-tenu de la longueur du texte, pourquoi te casses-tu la tête avec un div ? Tu peux utiliser l'attribut title de la balise a (et ainsi supprimer ta fonction over_Roger) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    code = code.replace(/Roger/g, '<a href="#" title="gentil le Roger">Roger</a>');
    et supprime le terme "javascript" après un événement (onclick, onmouseover, onmouseout, onchange, etc...) . Ne l'utilise que pour des pseudo-url. Exemple de pseudo-url :
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <a href="javascript: alert('coucou')">Pseudo-url</a>

  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 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
    de manière générale mieux vaut éviter les document.write pour ajouter des objets et leur attribuer des évènements... mieux vaut passer par le DOM...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    var newObj=document.createElement('a');
    newObj.href="javascript:Roger();return false;"
    newObj.innerHTML='coucou'
    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 Expert
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    1 252
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 252
    Par défaut
    ... et mieux vaut utiliser un <span> au lieu d'un <a> dans ce cas, sauf si Roger est réellement un lien.

  5. #5
    Membre Expert
    Avatar de Gruik
    Profil pro
    Développeur Web
    Inscrit en
    Juillet 2003
    Messages
    1 566
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juillet 2003
    Messages : 1 566
    Par défaut
    ... ou créer un <a> sans href ,)

  6. #6
    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
    avec un onclick et un style="cursor:pointer"
    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 !

  7. #7
    Membre averti Avatar de sansamis
    Inscrit en
    Janvier 2007
    Messages
    71
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 71
    Par défaut
    heu... up?

  8. #8
    Membre Expert
    Avatar de Gruik
    Profil pro
    Développeur Web
    Inscrit en
    Juillet 2003
    Messages
    1 566
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juillet 2003
    Messages : 1 566
    Par défaut
    Ah ça y'est
    Quelque part j'ai dit ".style.display = '' " pour "rafficher" un element.
    En fait ça remet la propriété display à sa valeur initiale je pense (celle positionnée par CSS).
    Ici la valeur initiale était "none"
    Il faudrait essayer avec "display = 'block'", je ne connais pas exactement le type de bloc qu'est un div, mais peut etre que c'est 'block'
    Voila

  9. #9
    Membre averti Avatar de sansamis
    Inscrit en
    Janvier 2007
    Messages
    71
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 71
    Par défaut
    Salut Gruik et merci d'être encore là pour moi

    Ben oui, "block" est bien (avec "inline" qui est sensiblement pareil) la valeur par défait de display, mais ca ne marche toujours pas (j'avais déjà essayé en enlevant le "display: none" par défaut mais ca marchait pas).

    Ca peux pas venir du fait que ca:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    document.body.innerHTML = ' '+code+'<div id="desc" style="position: absolute; display: none; background-color: #000000;"></div>';
    c'est pas correct ? il faut peut-être générer le div autrement, ailleur, à un autre moment, je sais pas... ca inspire personne ?

    Merci d'avance, su ce je vais me coucher et je reprendrai ca demain...

    Bonne nuit Gruik et bonne nuit tout le monde

  10. #10
    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
    créer le au depart su la page avec un style display none ... ?
    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 !

  11. #11
    Membre averti Avatar de sansamis
    Inscrit en
    Janvier 2007
    Messages
    71
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 71
    Par défaut
    Comment ca ? éxplique un poil plus s'il te plait

    Si tu parles de mettre document.write('<div id="desc" style="position: absolute; display: none; background-color: #000000;"></div>'); au début je viens d'essayer ca ne fonctionne pas :'(

Discussions similaires

  1. Comment créer des dbctrlgrid avec dbtext dynamiquement
    Par kameleon80 dans le forum Composants VCL
    Réponses: 5
    Dernier message: 20/03/2013, 10h18
  2. Créer un lien avec un truc qui s'affiche
    Par Marigogos dans le forum Dreamweaver
    Réponses: 1
    Dernier message: 13/07/2011, 12h51
  3. Réponses: 3
    Dernier message: 21/09/2003, 15h52
  4. créer un noeuds avec des paramétres
    Par Toxine77 dans le forum XMLRAD
    Réponses: 5
    Dernier message: 21/01/2003, 16h11
  5. [CR] Est il possible de créer des univers avec Seagate Info?
    Par Frank dans le forum SAP Crystal Reports
    Réponses: 1
    Dernier message: 27/06/2002, 15h22

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