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 :

setTimeout et touche echap


Sujet :

JavaScript

  1. #1
    Membre actif
    Inscrit en
    Février 2009
    Messages
    626
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 626
    Points : 237
    Points
    237
    Par défaut setTimeout et touche echap
    Bonjour,

    Des images utilisent (onclick / onkeyup). Lorsque je clique sur une image, celle-ci est zoomée via le plugin fluidbox...

    Le problème : sur le bord de l'image j'ai ajouté une petite icone "loupe" qui alterne un display none/block au clique de l'image ; setTimeout permet de réafficher l'icone après le temp de dézoomage, soit 1s. Tout fonctionne sauf avec la touche échap ; ça boucle, l'icone se masque et se réaffiche qu'il est en display block...


    J'ai observé que si je met à 0 le setTimeout de la touche échap ça ne boucle plus mais l'effet recherché est raté,

    Si vous avez une idée du problème, voici le code :

    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
    /*
     * Permet d'alterner l'affichage de l'icone zoom.
     * 
     */
    function zoomToggle(id)
    {
    	elmt = document.getElementById(id);
     
    	g_timer = null;
     
        if (elmt.style.display == "none") {
            // -SI- fermer avec touche « Echap »
        	$(document).keyup(function(e) {
        		setTimeout(function () {
        			if (e.keyCode == 27) {
        				elmt.style.display = 'block';
        			}
        		}, 500);
        	});	 
        	// -SI fermer avec la souris
        	setTimeout(function () {
        		elmt.style.display = 'block';
        	}, 500);
        }
        else {
        	elmt.style.display = 'none';
        }
    }

    Remerciement,

  2. #2
    Membre actif
    Inscrit en
    Février 2009
    Messages
    626
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 626
    Points : 237
    Points
    237
    Par défaut
    Désolé j'ai fini par trouvé la solution, suffisait de passer le z-index du CSS plus haut que l'image.. la solution est parfois moins compliquée...

  3. #3
    Expert éminent sénior
    Avatar de ProgElecT
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2004
    Messages
    6 107
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 68
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Décembre 2004
    Messages : 6 107
    Points : 16 630
    Points
    16 630
    Par défaut
    Salut

    Essais en modifiant légèrement la condition if de la ligne 15
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
        	$(document).keyup(function(e) {
        		setTimeout(function () {
        			//if (e.keyCode == 27) {
              let x = event.which || event.keyCode;
              if (x == 27) {
        				elmt.style.display = 'block';
        			}

  4. #4
    Membre actif
    Inscrit en
    Février 2009
    Messages
    626
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 626
    Points : 237
    Points
    237
    Par défaut
    Merci pour la correction de syntaxe même si je ne comprends pas à quoi ça sert,
    ma précédente syntaxe était compatible IE11/Edge, Chrome, Safari, FF, Opéra
    avec celle-ci, safari n'est plus compatible.

  5. #5
    Expert confirmé Avatar de psychadelic
    Profil pro
    Inscrit en
    Mai 2010
    Messages
    2 529
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2010
    Messages : 2 529
    Points : 4 749
    Points
    4 749
    Par défaut
    ou plutôt
    Code JavaScript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
      $(document).keyup(function (e) {
        setTimeout(f_display_elmt, 500, e);
      });
     
      function f_display_elmt( evt ) {
        if (evt.keyCode == 27) {
          elmt.style.display =  'block';
        }
      }
    ?

    mais ça me semble bizarre de toute façons d'avoir "coincé" une gestion d’événements à l'intérieur d'un if

  6. #6
    Expert éminent
    Avatar de Watilin
    Homme Profil pro
    En recherche d'emploi
    Inscrit en
    Juin 2010
    Messages
    3 094
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : En recherche d'emploi

    Informations forums :
    Inscription : Juin 2010
    Messages : 3 094
    Points : 6 755
    Points
    6 755
    Par défaut
    Citation Envoyé par psychadelic Voir le message
    mais ça me semble bizarre de toute façons d'avoir "coincé" une gestion d’événements à l'intérieur d'un if
    À moi aussi, ça me semble bizarre. La méthode $(document).keyup( ... ) est appelée à chaque appel à zoomToggle, autrement dit les gestionnaires d’évènements keyup se multiplient sans limite. Ça a le potentiel de geler l’onglet / le navigateur. Il faut absolument corriger ça.

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

Discussions similaires

  1. [XL-2016] Code VBA qui marche uniquement avec la touche ECHAP?
    Par swirzel dans le forum Macros et VBA Excel
    Réponses: 23
    Dernier message: 23/03/2018, 12h27
  2. [PPT-2013] Sauvegarder PPT avant fermeture avec touche ECHAP
    Par Ghost0000 dans le forum Powerpoint
    Réponses: 0
    Dernier message: 08/02/2016, 11h19
  3. fermer gnuplot appelé en c avec la touche "echap"
    Par bobby-wan dans le forum Windows
    Réponses: 0
    Dernier message: 22/04/2009, 10h53
  4. Réponses: 12
    Dernier message: 30/07/2004, 15h43
  5. Comment gérer la touche echap ?
    Par Adrael dans le forum C
    Réponses: 28
    Dernier message: 11/07/2003, 13h15

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