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 :

onKeyPress et Firefox


Sujet :

JavaScript

  1. #1
    Nouveau membre du Club Avatar de Bateau_Ivre
    Inscrit en
    Janvier 2008
    Messages
    61
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 61
    Points : 36
    Points
    36
    Par défaut onKeyPress et Firefox
    Bonjour,

    Quand on appuie sur la touche "entrée", l'évènement est bien géré par IE.
    Pas par firefox ...


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <input class="rechercheAccueilTexte" id="recherche" type="text" name="rech" value="Recherche" onKeyPress="if (event.keyCode==13) event.keyCode=0;">
    Pourquoi ?

    Merci d'avance.

  2. #2
    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 637
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    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 637
    Points : 66 658
    Points
    66 658
    Billets dans le blog
    1
    Par défaut
    histoire de charcode vs keycode ...
    onkeydown ?

    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
    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
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
     
    <html>
    <head>
    <title>Keyboard Events and Codes</title>
    <style type="text/css">
    body         { font-family: Arial, sans-serif }
    h1           { text-align: right }
    td           { text-align: center }
    </style>
     
     
    <script language="JavaScript" type="text/javascript">
    // array of table cell ids
    var tCells = ["downKey", "pressKey", "upKey", "downChar", "pressChar", "upChar", "keyTarget", "character"];
    // clear table cells for each key down event 
    function clearCells() {
    	for (var i = 0; i < tCells.length; i++) {
    			document.getElementById(tCells[i]).innerHTML = "&mdash;"; 
    			} 
    } 
     
    // display target node's node name
    function showTarget(evt) { 
    	var node = (evt.target) ? evt.target : ((evt.srcElement) ? evt.srcElement : null); 
    	if (node) { 
    				document.getElementById("keyTarget").innerHTML = node.nodeName; 
    				}
    		 }
     
    // decipher key down codes 
    function showDown(evt) {
    		clearCells(); 
    		evt = (evt) ? evt : ((event) ? event : null); 
    		if (evt) { document.getElementById("downKey").innerHTML = evt.keyCode; 
    					if (evt.charCode) { 
    											document.getElementById("downChar").innerHTML = evt.charCode; 
    											} 
    					showTarget(evt); }
    		}
     
     // decipher key press codes 
     function showPress(evt) {
     		 evt = (evt) ? evt : ((event) ? event : null);
     		 if (evt) {
     		 			 document.getElementById("pressKey").innerHTML = evt.keyCode;
     		 			 if (evt.charCode) {
     		 			 						document.getElementById("pressChar").innerHTML = evt.charCode;
     		 			 						} 
     		 			 showTarget(evt);
     		 			 var charCode = (evt.charCode) ? evt.charCode : evt.keyCode; 
     		 			 // use String method to convert back to character 
     		 			 document.getElementById("character").innerHTML = String.fromCharCode(charCode); 
     		 			 }
     		 	}
     
    // decipher key up codes 
    function showUp(evt) {
    					evt = (evt) ? evt : ((event) ? event : null);
    					if (evt) { document.getElementById("upKey").innerHTML = evt.keyCode;
    								if (evt.charCode) { 
    													  document.getElementById("upChar").innerHTML = evt.charCode; 
    													  } 
    								showTarget(evt); 
    								}
    					 }
     
    // set page-wide event listeners
     document.onkeydown = showDown; 
     document.onkeypress = showPress; 
     document.onkeyup = showUp; 
     </script> 
     
     
     
    </head>
     
    <body>
    <h1>Key and Character Codes vs. Event Types</h1>
    <hr>
    <p>Enter some text with uppercase and lowercase letters:<br>
    </p>
    <form>
    	<input type="text" id="entry" size="60" onkeydown="showDown(event)"	onkeypress="showPress(event)" onkeyup="showUp(event)">
    </form>
    <table border="2" cellpadding="5" cellspacing="5">
    	<caption>Keyboard Event Properties</caption>
    	<tr>
    		<th>Data</th>
    		<th>keydown</th>
    		<th>keypress</th>
    		<th>keyup</th>
    	</tr>
    	<tr>
    		<td>keyCode</td>
    		<td id="downKey">—</td>
    		<td id="pressKey">—</td>
    		<td id="upKey">—</td>
    	</tr>
    	<tr>
    		<td>charCode</td>
    		<td id="downChar">—</td>
    		<td id="pressChar">—</td>
    		<td id="upChar">—</td>
    	</tr>
    	<tr>
    		<td>Target</td>
    		<td id="keyTarget" colspan="3">—</td>
    	</tr>
    	<tr>
    		<td>Character</td>
    		<td id="character" colspan="3">—</td>
    	</tr>
     
     
    </table>
     
    </body>
    </html>
    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 !

  3. #3
    Nouveau membre du Club Avatar de Bateau_Ivre
    Inscrit en
    Janvier 2008
    Messages
    61
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 61
    Points : 36
    Points
    36
    Par défaut
    Non : onKeyDown ne fonctionne pas ...

  4. #4
    Expert éminent sénior

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Points : 36 571
    Points
    36 571
    Par défaut
    Bonjour,
    Citation Envoyé par Bateau_Ivre Voir le message
    Quand on appuie sur la touche "entrée", l'évènement est bien géré par IE.
    Pas par firefox ...
    Apparemment, c'est plutôt que IE permet de le modifier alors que FF, non.
    Testé avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <input class="rechercheAccueilTexte" id="recherche" type="text" name="rech" value="Recherche" onKeyPress="alert(event.keyCode);event.keyCode=0;alert(event.keyCode);">
    A+
    Pour tout savoir sur l'utilisation du forum

    En postant votre message, n'oubliez pas les Règles du Club.

  5. #5
    Nouveau membre du Club Avatar de Bateau_Ivre
    Inscrit en
    Janvier 2008
    Messages
    61
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 61
    Points : 36
    Points
    36
    Par défaut
    En fait, je veux interdire toute réaction à la touche entrée sur cette balise.
    Et Sous IE, ca fonctionne comme je veux.
    Pas sous Firefox.
    Je me suis peut-être mal exprimé.

  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 637
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    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 637
    Points : 66 658
    Points
    66 658
    Billets dans le blog
    1
    Par défaut
    regarde le code fourni plus haut tu verras comment detecter les touches et par conséquent les inhiber ..
    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 !

Discussions similaires

  1. Firefox : onkeypress et la touche échap
    Par rdummies dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 09/04/2008, 13h52
  2. [DOM] Méthode initKeyEvent sur un onKeyPress avec Firefox
    Par jers85 dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 10/01/2008, 11h13
  3. [JavaScript] firefox et onKeypress
    Par dahu29 dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 18/12/2006, 18h17
  4. Firefox et onkeypress
    Par simoryl dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 12/01/2006, 13h39

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