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

jQuery Discussion :

Détecte les changements d'un formulaire


Sujet :

jQuery

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    100
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 100
    Par défaut Détecte les changements d'un formulaire
    Bonjour,

    J'ai un formulaire. Et je veux faire un contrôle pour vérifier si l'utilisateur quitte le formulaire avec des modifications en cours non validées.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    //Vérifie si le formulaire est modifié
    $(':input',document.<%=request.getParameter("formName")%>).bind("change", function() { 
    	dataChanged = true; 
    });
    Ce code fonctionne bien avec les champs texte.
    Mais si je coche une checkbox (ou un radio button) et que je la décoche après, il déclenche l'évènement. Alors que rien n'est modifié.

    Avez-vous une idée ?

  2. #2
    Membre confirmé
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2003
    Messages
    120
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2003
    Messages : 120
    Par défaut
    Je déterre un peu ce sujet mais j'ai été confronté au cas hier... Je poste donc ma solution ici, ça peut toujours servir.

    A l'initialisation:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    var gFormSnapshot;
    $(document).ready( function(){
    ...
     
    gFormSnapshot = $('#form').serializeArray();
    });
    Fonction à utiliser pour savoir si le formulaire a été modifié:
    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
     
    function formHasChange(){
    	var notChanged	= true;
    	var currentForm		= $('#form').serializeArray();
    	var snapshotLen		= gFormSnapshot.length;
     
    	if( currentForm.length != snapshotLen ){
    		return true;
    	} else {
    		var i=0, j=0;
    		var find = false;
    		while( i < snapshotLen && notChanged ){
    			find = false;
    			while( j < snapshotLen && !find){
    				if( gFormSnapshot[i].name == currentForm[j].name ){
    					notChanged = notChanged && gFormSnapshot[i].value == currentForm[j].value;
    					find = true;
    				}
    				j++;
    			}
    			if( !find ){ return true;}
    			i++;
    		}
    	}
    	return !notChanged;
    }

Discussions similaires

  1. Réponses: 4
    Dernier message: 16/02/2012, 14h27
  2. [AC-2000] Requète de sous formulaire ne prend pas en compte les changements
    Par switchON dans le forum VBA Access
    Réponses: 11
    Dernier message: 26/05/2011, 09h49
  3. Réponses: 1
    Dernier message: 27/10/2004, 15h36
  4. les changements du protocol ipv4 ----> ipv6
    Par m-unix dans le forum Développement
    Réponses: 1
    Dernier message: 26/10/2004, 19h58
  5. Réponses: 18
    Dernier message: 22/10/2004, 14h49

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