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 :

Simplification d'une fonction - gestion des événements


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Développeur Web
    Inscrit en
    Octobre 2006
    Messages
    66
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Octobre 2006
    Messages : 66
    Par défaut Simplification d'une fonction - gestion des événements
    Bonjour !

    J'ai une fonction... qui fonctionne, mais que j'aimerais améliorer.
    Le but est d'avoir le comportement suivant :
    - A l'arrivée sur un formulaire, certains inputs sont grisés (mais pas désactivés) et contiennent la description de ce qu'ils devront contenir (en l'occurence, "Nom" et "Prénom").
    - Lorsque le focus et donné à un de ces input, le contenu s'efface, l'input n'est plus grisé et l'utilisateur peut écrire dans l'input de façon normale
    - Si rien n'a été saisi et que le focus est perdu, l'input redevient grisé, et la description du contenu s'affiche de nouveau

    Pour le moment, j'ai procédé de cette manière:
    Coté HTML:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    <style type='text/css'>
    	input.labeled{
    		color: grey;
    		font-style: italic;
    	}
    </style>
    <label for='entreprise'>Entreprise</label>
    <input type='text' id='entreprise' name='entreprise' />
    <br />
    <input type='text' name='nom' value='Nom' onfocus='labeled_input(this);' />
    <input type='text' name='prenom' value='Prénom' onfocus='labeled_input(this);' />
    Coté 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
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    function labeled_input(input){
    	if(input && input.className == 'labeled'){
     
    		if(input.value == 'Nom')
    		{
    			input.onblur = function(){
    				if(this.value == '')
    				{
    					this.className = 'labeled';
    					this.value = "Nom";
    				}
    			};
    		}
    		else if(input.value == 'Prénom')
    		{
    			input.onblur = function(){
    				if(this.value == '')
    				{
    					this.className = 'labeled';
    					this.value = "Prénom";
    				}
    			};
    		}
    		input.value = '';
    		input.className = '';
    	}
    }
    Cela fonctionne, mais uniquement pour des champs qui contiendraient "Prénom" ou "Nom".
    En gros, c'est cette partie qui me dérange
    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
    		if(input.value == 'Nom')
    		{
    			input.onblur = function(){
    				if(this.value == '')
    				{
    					this.className = 'labeled';
    					this.value = "Nom";
    				}
    			};
    		}
    		else if(input.value == 'Prénom')
    		{
    			input.onblur = function(){
    				if(this.value == '')
    				{
    					this.className = 'labeled';
    					this.value = "Prénom";
    				}
    			};
    		}
    Je voudrais "tout simplement" pouvoir faire varier la chaine "Prénom" ou "Nom" en fonction du contenu de l'input (histoire de ne pas avoir à répéter l'assignation de l'événement pour chaque différente valeur possible).

    Si ce n'est pas clair, n'hésitez pas à demander plus d'infos

    Merci d'avance !

  2. #2
    Expert éminent

    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
    Par défaut
    Bonjour,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    input.onblur = function(){
    			if(this.value == '')
    			{
    				this.className = 'labeled';
    				this.value = input.value;
    			}
    };
    Non ?

    A+

  3. #3
    Membre confirmé
    Profil pro
    Développeur Web
    Inscrit en
    Octobre 2006
    Messages
    66
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Octobre 2006
    Messages : 66
    Par défaut
    C'est ce que j'avais pensé, mais non.
    Car dans
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    input.onblur = function(){
    	if(this.value == '')
    	{
    		this.className = 'labeled';
    		this.value = input.value;
    	}
    };
    input est pris dans le référentiel de la fonction.
    Donc quand ma fonction sera appelée input, ne signifiera plus rien (ce n'est pas une variable globale).

  4. #4
    Expert éminent

    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
    Par défaut
    Ah ouais !
    Pas fais attention
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    input.onblur = function(){
    			if(this.value == '')
    			{
    				this.className = 'labeled';
    				this.value = (this.name=='nom')?'Nom':'Prénom';
    			}
    };
    A+

  5. #5
    Membre confirmé
    Profil pro
    Développeur Web
    Inscrit en
    Octobre 2006
    Messages
    66
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Octobre 2006
    Messages : 66
    Par défaut
    Oui j'y avais pensé aussi d'utiliser l'attribut name.
    Le souci, c'est que dans ce cas, je ne peux toujours utiliser mon script que pour "Prénom" ou "Nom".
    Bon, on peut toujours ajouter d'autres conditions pour d'autres valeurs, mais ça fonctionnera toujours pour une quantité finie de valeur.
    Et plus j'ajouterai de cas plus mon code sera lourd et laid.

    C'est quand même étrange, on est dans la fonction labeled_input, on a la valeur qu'on veut sous la main, mais on ne peut pas l'utiliser.

    Il doit bien y avoir un moyen...

  6. #6
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    this.value = this.className;
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

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

Discussions similaires

  1. [WD15] Gestion des événements clavier dans une fenêtre.
    Par dvdbly dans le forum WinDev
    Réponses: 3
    Dernier message: 20/09/2010, 08h58
  2. Gestion des évènements avec une superposition d'éléments
    Par Meardon dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 26/10/2008, 14h47
  3. Gestion des évènements lors d'un clique sur une image.
    Par yoghisan dans le forum Débuter
    Réponses: 7
    Dernier message: 23/06/2005, 19h04
  4. Erreur sur une fonction avec des paramètres
    Par Elois dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 05/05/2004, 21h00
  5. Une fonction avec des attributs non obligatoires
    Par YanK dans le forum Langage
    Réponses: 5
    Dernier message: 15/11/2002, 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