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 :

Bouton "Lire la suite" Multilingue


Sujet :

JavaScript

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    décembre 2019
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : décembre 2019
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Bouton "Lire la suite" Multilingue
    Bonjour à tous,

    Je suis débutant en JS et je souhaite connaître la façon de créer un bouton "Lire la suite" en plusieurs langue pour un site.

    J'essaie d'appliquer un code que j'ai trouvé ici : https://www.w3schools.com/howto/tryi...w_js_read_more

    Le soucis, c'est que je n'arrive pas à faire fonctionner pour les deux langues (fr + en). L'anglais fonctionne, mais pas le français ou inversement.
    J'ai beau tourner le problème dans tous les sens, les deux ne fonctionnent jamais en même temps.

    Peut être cela vient il de myFunction() ??

    Merci beaucoup si vous avez une piste à me proposer.

    Christophe

    Voici le détail du code :

    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
    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
    55
    56
    <!DOCTYPE html>
    <html>
    <head>
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <style>
    #more {display: none;}
    </style>
    </head>
    <body>
     
    <h2>Read More Read Less Button</h2>
    <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Phasellus imperdiet, nulla et dictum interdum, nisi lorem egestas vitae scel<span id="dots">...</span><span id="more">erisque enim ligula venenatis dolor. Maecenas nisl est, ultrices nec congue eget, auctor vitae massa. Fusce luctus vestibulum augue ut aliquet. Nunc sagittis dictum nisi, sed ullamcorper ipsum dignissim ac. In at libero sed nunc venenatis imperdiet sed ornare turpis. Donec vitae dui eget tellus gravida venenatis. Integer fringilla congue eros non fermentum. Sed dapibus pulvinar nibh tempor porta.</span></p>
    <button onclick="myFunction()" id="myBtn_fr">Lire plus</button>
     
    <h2>Read More Read Less Button</h2>
    <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Phasellus imperdiet, nulla et dictum interdum, nisi lorem egestas vitae scel<span id="dots">...</span><span id="more">erisque enim ligula venenatis dolor. Maecenas nisl est, ultrices nec congue eget, auctor vitae massa. Fusce luctus vestibulum augue ut aliquet. Nunc sagittis dictum nisi, sed ullamcorper ipsum dignissim ac. In at libero sed nunc venenatis imperdiet sed ornare turpis. Donec vitae dui eget tellus gravida venenatis. Integer fringilla congue eros non fermentum. Sed dapibus pulvinar nibh tempor porta.</span></p>
    <button onclick="myFunction()" id="myBtn_en">Read more</button>
     
    <script>
    function myFunction() {
      var dots = document.getElementById("dots");
      var moreText = document.getElementById("more");
      var btnText = document.getElementById("myBtn_fr");
     
      if (dots.style.display === "none") {
        dots.style.display = "inline";
        btnText.innerHTML = "Lire plus"; 
        moreText.style.display = "none";
      } else {
        dots.style.display = "none";
        btnText.innerHTML = "Lire moins"; 
        moreText.style.display = "inline";
      }
    }
    </script>
     
    <script>
    function myFunction() {
      var dots = document.getElementById("dots");
      var moreText = document.getElementById("more");
      var btnText = document.getElementById("myBtn_en");
     
      if (dots.style.display === "none") {
        dots.style.display = "inline";
        btnText.innerHTML = "Read more"; 
        moreText.style.display = "none";
      } else {
        dots.style.display = "none";
        btnText.innerHTML = "Read less"; 
        moreText.style.display = "inline";
      }
    }
    </script>
     
    </body>
    </html>

  2. #2
    Modérateur

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

    Informations forums :
    Inscription : janvier 2011
    Messages : 13 951
    Points : 34 254
    Points
    34 254
    Par défaut
    Bonjour et bienvenue sur DVP.

    Comme dans ton code tu définies deux fois la fonction myFunction c'est la dernière déclarée qui est « conservée » par JavaScript.

    Pour régler ton problème il te faut factoriser ta fonction, n'en faire qu'une avec passage de paramètre, et de l'appeler en conséquence, par exemple :
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    <button onclick="myFunction('fr')" id="myBtn_fr">Lire plus</button>
     <!-- -->
    <button onclick="myFunction('en')" id="myBtn_en">Read more</button>

    Attention une ID doit être UNIQUE ce qui n'est pas le cas dans ta page :
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    <span id="dots">...</span><span id="more">

Discussions similaires

  1. lire une suite d'image
    Par freemoh_01 dans le forum C++Builder
    Réponses: 1
    Dernier message: 21/03/2008, 02h23
  2. Réponses: 4
    Dernier message: 01/08/2006, 13h24
  3. [FLASH MX2004] Bouton pour lire vidéo
    Par kiki93 dans le forum Flash
    Réponses: 10
    Dernier message: 23/11/2004, 12h50

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