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 :

Boutons voir+ voir -


Sujet :

JavaScript

  1. #1
    Membre éclairé Avatar de ypcman
    Homme Profil pro
    Retraité codeur !
    Inscrit en
    Janvier 2011
    Messages
    597
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Retraité codeur !
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2011
    Messages : 597
    Points : 886
    Points
    886
    Par défaut Boutons voir+ voir -
    Bonjour.
    Mon objectif est le suivant :
    je veux pouvoir, au sein d'un formulaire, afficher par défaut le début d'un texte avec , à coté un bouton Voir+. Après appui sur ce bouton, le texte complet s'affiche ainsi qu'un bouton Voir-. En appuyant sur ce second bouton, je reviens à l'affichage réduit intial.
    J'ai écrit 2 fonctions js "voir_plus()" et "voir_moins() dans un script test.js :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    var texte = "Ceci est le texte que je veux pouvoir montrer en format réduit ou non";
    document.getElementById("p1").innerHTML = texte.substring(0, 20);
     
    function voir_plus(id, texte) {
    	document.getElementById("p" + id).innerHTML = texte
    	document.getElementById("fbutton" + id).value = 'Voir -';
    	// document.getElementById("fbutton" + id).setAttribute('onClick', voir_moins(id, texte));
    }
     
    function voir_moins(id, texte) {
    	document.getElementById("p" + id).innerHTML = texte.substring(0, 20)
    	document.getElementById("fbutton" + id).value = 'Voir +';
    	document.getElementById("fbutton" + id).setAttribute('onClick', voir_plus(id, texte));
    }
    et une page de test :
    Code HTML : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="UTF-8">
    <title>JS Test</title>
    </head>
    <body>
    <form>
    <p id="p1"></p>
    <input id="fbutton1" type="button" value="Voir +"  onClick="voir_plus('1',texte)">
    </form>
    <script src="test.js";></script>
    </body>
    </html

    Mon pb actuel, c'est que je ne réussis pas à changer la valeur du onClick sans que l'action soit réalisée. Si, dans voir_plus, j'enlève le commentaire de la ligne modifiant la valeur de onClick, la fonction exécute cette ligne comme si je lui demandais de simuler un click alors que je veux juste dire que la prochaine fois qui'l y aura un clic, l'action sera différente.
    Le id c'est juste que je compte insérer cette fonctionnalité dans une table avec de multiples lignes

    Bref, je suis un peu perdu. merci de vos lumières
    Participez vous aussi !
    Message utile
    Discussion résolue

  2. #2
    Modérateur

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

    Informations forums :
    Inscription : Janvier 2011
    Messages : 16 959
    Points : 44 122
    Points
    44 122
    Par défaut
    Bonjour,
    lorsque tu écris
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    document.getElementById("fbutton" + id).setAttribute('onClick', voir_moins(id, texte))
    tu affectes à onClick le résultat de la fonction voir_moins.

    Si tu souhaites rester dans cette façon de faire il te faut dans ce cas passer par l'affectation d'une fonction anonyme qui, elle, appellera ta fonction.
    Par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    function voir_plus(id, texte) {
        document.getElementById("p" + id).innerHTML = texte
        document.getElementById("fbutton" + id).value = 'Voir -';
        //document.getElementById("fbutton" + id).setAttribute('onClick', voir_moins(id, texte));
        document.getElementById("fbutton" + id).onclick = () => {
            voir_moins(id, texte);  
        };
    }
    Le id c'est juste que je compte insérer cette fonctionnalité dans une table avec de multiples lignes
    il y aura surement une autre façon de faire que d'utiliser une ribambelle d'ID.

  3. #3
    Membre éclairé Avatar de ypcman
    Homme Profil pro
    Retraité codeur !
    Inscrit en
    Janvier 2011
    Messages
    597
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Retraité codeur !
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2011
    Messages : 597
    Points : 886
    Points
    886
    Par défaut
    Bonsoir NoSmoking.
    Ton post résout parfaitement mon problème.
    merci !
    Participez vous aussi !
    Message utile
    Discussion résolue

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

Discussions similaires

  1. Réponses: 19
    Dernier message: 02/03/2018, 22h16
  2. [AC-2010] Problème de zone de sélection aprés voir redimensionné un bouton
    Par Razmote dans le forum VBA Access
    Réponses: 1
    Dernier message: 11/07/2014, 14h34
  3. Affichage tabulaire avec bouton "voir plus"
    Par laurentSc dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 08/11/2013, 17h14
  4. pas voir boutons (AWT / GridBagLayout)
    Par temoanatini dans le forum Agents de placement/Fenêtres
    Réponses: 4
    Dernier message: 06/06/2009, 20h45
  5. Réponses: 8
    Dernier message: 15/02/2007, 09h02

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