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 :

Modifier une zone de texte SVG en JavaScript [infobulle]


Sujet :

JavaScript

  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2011
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2011
    Messages : 35
    Par défaut Modifier une zone de texte SVG en JavaScript [infobulle]
    Bonsoir, après avoir cherché en vain une section SVG, je poste mon problème dans ce topic.

    Je cherche à créer une infobulle au survol d'un secteur SVG.
    Je voudrais donc modifier la valeur de l'infobulle en fonction du secteur. Jusque là tout fonctionne, j'obtiens le résultat:
    Champ1:XXX Champ2:XXX Champ3:XXX Champ4:XXX

    Mais je voudrais obtenir ceci:
    Champ1:XXX
    Champ2:XXX
    Champ3:XXX
    Champ4:XXX

    Comme je modifie le contenu texte d'une balise <text>, je cherche à le faire grâce aux balises <tspan>.

    Voici mon code actuel:

    Balise dans le HTML:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <text id="ZoneInfobulle" fill-opacity="0">Zone de texte</text>
    Fonction Javascript:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
                  svgdoc = evt.target.ownerDocument;  //Récupération de l'évènement
    			var objet = svgdoc.getElementById("ZoneInfobulle");  //Identification de l'objet à modifier
    			var child = objet.firstChild;  
     
    			affichage = "Champ1:XXX<tspan>Champ2:XXX</tspan><tspan>Champ3:XXX</tspan><tspan>Champ4:XXX</tspan>";
     
    			child.data = affichage;  //Modification
    Le problème c'est que les balises n'ont pas d'effets et que le balises apparaissent dans l'infobulle, donc je voie ceci:
    <tspan>Champ1:XXX</tspan><tspan>Champ2:XXX</tspan><tspan>Champ3:XXX</tspan><tspan>Champ4:XXX</tspan>
    Pouvez m'aider à rendre ces balises actives ?

    Cordialement

  2. #2
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 198
    Par défaut
    Bonjour,
    je ne connais pas la technique SVG, mais as tu essayé avec firstChild.nodeValue,
    ou encore par la méthode de création des éléments createElementNS

  3. #3
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2011
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2011
    Messages : 35
    Par défaut
    Merci de la réponse.
    Je viens d'essayer avec la méthode createElementNS, j'obtiens le même résultat
    Je vais essayer avec firstChild.nodeValue et je donne le résultat.

Discussions similaires

  1. [VBA-W]Inserer et modifier une Zone de texte
    Par marsupoilu dans le forum VBA Word
    Réponses: 5
    Dernier message: 17/04/2019, 09h22
  2. [AC-2003] Modifier une zone de texte basée sur column
    Par maringot dans le forum IHM
    Réponses: 3
    Dernier message: 22/10/2009, 15h23
  3. Réponses: 13
    Dernier message: 30/10/2006, 11h16
  4. Modifier une zone de texte désigné par la fonction eval(concat de variables)
    Par Franck2mars dans le forum Général JavaScript
    Réponses: 8
    Dernier message: 19/07/2006, 11h43
  5. ne pas modifier une zone de texte
    Par gailup dans le forum Langage
    Réponses: 3
    Dernier message: 22/06/2006, 19h28

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