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 :

Rejeter une frappe


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif
    Homme Profil pro
    Retraité
    Inscrit en
    Février 2009
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2009
    Messages : 22
    Par défaut Rejeter une frappe
    Bonjour,
    J'utilise l'évènement keypress pour gérer la frappe 'en live'.
    Cependant, je ne sais comment rejeter une frappe incorrecte.
    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
    	function miseEnForme (evt)
    	{
    		element = evt.target ;
    		c = evt.key ;
    		num = element.value ;
    		if (! c.match(/[0-9.,]/) || (c.match(/[.,]/) && num.match(/[.,]/)))
    		{
    			alert("refusé : num = " + num) ;
    			element.value = num ;
    			return ;
    		}		
    		num += c ;
    		resu = euro.format (num) ;
    		et = document.getElementById(element.id +"-txt") ;
    		et.value = resu ;
    	}
    Note : À chaque élément correspond un élément -txt pour visualiser le format en €.

    Problème : le caractère frappé apparait toujours dans le champ. Comment s'en débarrasser ?

  2. #2
    Membre Expert Avatar de darkstar123456
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2008
    Messages
    1 895
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mars 2008
    Messages : 1 895
    Par défaut
    Bonjour,

    Le code est pratiquement correct.
    Le problème est que le comportement par défaut doit être bloqué
    Pour cela, on utilise event.preventDefault();, voici un exemple : https://codepen.io/DarkStar123456/pe...G?editors=0010

    Par contre, ce qui me choque un peu, c'est que vous réécrivez le mode de fonctionnement de l'input type="number".
    Si vous souhaitez ajouter un suffixe €, il devrait se trouver en dehors de l'input.
    D'autant plus qu'il modifie la valeur de type "nombre" (entier ou float) en type string), ce qui empêcherait n'importe quel futur calcul à faire

  3. #3
    Membre actif
    Homme Profil pro
    Retraité
    Inscrit en
    Février 2009
    Messages
    22
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2009
    Messages : 22
    Par défaut
    Merci, c'est exactement ce que je voulais.
    Précision : le champ transmis par le FORM est le champ traité par cette miseEnForme est de type="monnaie" donc "text". Le champ -txt ne sert qu'à visualiser un résultat en bonne écriture d'€. Ce champ n'est pas transmis. Seul est transmis le champ traité sans mise en forme.

    Pourquoi tout ça ? Parce que l'utilisation d'un pattern n'est pas 'in live'. L'utilisation d'un type="number" impose un +- et un pas de 0.01 dans mon cas ...

  4. #4
    Membre Expert
    Avatar de Doksuri
    Profil pro
    Développeur Web
    Inscrit en
    Juin 2006
    Messages
    2 495
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 495
    Par défaut
    petite subtilite : developer.mozilla.org/fr/docs/Web/API/Document/keypress_event
    Cette fonctionnalité a été supprimée des standards du Web
    Cet évènement est déprécié et il faudrait plutôt utiliser beforeinput ou keydown (en-US).
    La forme des pyramides prouve que l'Homme a toujours tendance a en faire de moins en moins.

    Venez discuter sur le Chat de Développez !

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

Discussions similaires

  1. Cyanogen Inc aurait rejeté une offre de rachat de Google
    Par Hinault Romaric dans le forum Android
    Réponses: 5
    Dernier message: 07/10/2014, 12h09
  2. Transférer une frappe d'un utilisateur vers une autre page
    Par sevyc dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 25/02/2013, 14h13
  3. [Debutant] Simuler une frappe clavier
    Par SofEvans dans le forum Langage
    Réponses: 3
    Dernier message: 11/07/2011, 10h02
  4. Ouvrir un formulaire par une frappe au clavier
    Par ozerte dans le forum IHM
    Réponses: 10
    Dernier message: 11/10/2008, 13h41
  5. Interdire une frappe d'un caractére non numérique
    Par fatati dans le forum C++Builder
    Réponses: 13
    Dernier message: 12/12/2006, 09h56

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