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 :

Maintenir une fenêtre flottante ouverte après la validation des données


Sujet :

jQuery

  1. #1
    Membre éclairé
    Inscrit en
    Juillet 2005
    Messages
    266
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 266
    Par défaut Maintenir une fenêtre flottante ouverte après la validation des données
    Bonjour à tous,

    J'ai réalisé une fenêtre flottante, elle fonctionne parfaitement bien. Grâce à cette fenêtre, je peux modifier ou créer des nouvelles données. Je l'ai réalisé ainsi:
    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
    $(document).ready(function() {			
    		var myTitle;
    		$('#nv').click(function(event) { 
    			$('#creer').load('test1?action=create');	
    			$('#creer').dialog({
    				modal: true,
    				height: 550, 
    				width: 1250,
    				autoOpen: false,
    				title: myTitle,
    				show: "blind",
    				hide: "explode"
    			});
    			$('#creer').dialog('open');		
    			event.stopPropagation();
    			event.preventDefault();
    		});
    	});
    Mais lors de la création de nouvelles données, je ne voudrais pas qu'elle se ferme après avoir cliquer sur le boutton enregistrer. Ainsi elle me permettra de faire d'autre enregistrement sans toutefois l'appeler de nouveau.

    Merci de votre aide et bonne journée.

  2. #2
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 198
    Par défaut
    Bonjour,
    je peux modifier ou créer des nouvelles données.
    si tes données sont transmises grâce à un formulaire la page est rechargée, dans ce cas il te faut utiliser la technique Ajax.

  3. #3
    Rédacteur

    Avatar de danielhagnoul
    Homme Profil pro
    Étudiant perpétuel
    Inscrit en
    Février 2009
    Messages
    6 389
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant perpétuel
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2009
    Messages : 6 389
    Billets dans le blog
    125
    Par défaut
    AJAX est asynchrone, il faut donc travailler dans la fonction de rappel (callback) de "load".

    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
    $( function(){ // forme abrégée de $(document).ready( function( ){
     
      var myTitle; // initialisation ?
     
      $( '#nv' ).on( "click", function( event ){
        event.stopPropagation();
        event.preventDefault();
     
        $( '#creer' ).load( 'test1?action=create', function(){
     
          $( this ).dialog({
            "modal" : true,
            "height" : 550, 
            "width" : 1250,
            "autoOpen" : true,
            "title" : myTitle,
            "show" : "blind",
            "hide" : "explode"
          });
     
        });
     
      });
     
    });

    Blog

    Sans l'analyse et la conception, la programmation est l'art d'ajouter des bogues à un fichier texte vide.
    (Louis Srygley : Without requirements or design, programming is the art of adding bugs to an empty text file.)

  4. #4
    Membre éclairé
    Inscrit en
    Juillet 2005
    Messages
    266
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 266
    Par défaut
    Bonjour à tous,

    Grâce à ce code, je peux envoyer mes données pour enregistrement dans la base de données.
    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
    $(document).ready(function(){
    		$("relance").submit(function(e){
    			 e.preventDefault();
    		});
    		$("#enregistrer").click(function(e){
                dataString = $("#relance").serialize();   
                var st_pret = $('#val1').val();
                dataString ='st_pret='+st_pret;            
                $.ajax({
                    type: "POST",
                    url: "valide_data?action=create",
                    data: dataString,
                	success : function(e){
                		if(data.success){
                			alert("ok");
                		} else {
                			alert("pas ok");
                		}
                	}    
                });
                e.preventDefault();
    		});
    		return false;
    	});
    Grâce à ma servlet valide_data, les données sont enregistrées sans problème et ma fenêtre flottante se ferme. Je vous signale dans ma servlet j'ai cette commande
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    this.getServletContext().getRequestDispatcher(VUE).forward(req, resp);
    pour afficher la page parent de la fenêtre flottante. Après avoir supprimé cette ligne, les données sont enregistrées mais au lieu que la fenêtre flottante reste, j'ai plutôt une page blanche.

    Mais lorsque la servlet de validation à générer une erreur à cause des violation de contrainte de la base de données, la fenêtre flottante ne se ferme pas. tant je ne l'ai pas fait volontairement.

    Merci de votre aide.

Discussions similaires

  1. Afficher une fenêtre de confirmation après la vérification des inputs
    Par natalie75 dans le forum Développement Web en Java
    Réponses: 0
    Dernier message: 27/04/2015, 09h06
  2. Utilisation d'une fenêtre flottante
    Par ChPr dans le forum NetBeans
    Réponses: 1
    Dernier message: 08/05/2007, 10h42
  3. Réponses: 1
    Dernier message: 20/11/2006, 14h04
  4. Fermer une popup d'attente après la validation d'un traitement
    Par outlawz dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 10/10/2006, 03h05
  5. Créer une fenêtre flottante qui ne peut avoir le focus
    Par BestofMac dans le forum Composants VCL
    Réponses: 4
    Dernier message: 17/07/2002, 10h46

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