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

Django Python Discussion :

Affichage après envoie de donnée d'une page à une autre (avec Ajax)


Sujet :

Django Python

Mode arborescent

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Novembre 2009
    Messages
    212
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Novembre 2009
    Messages : 212
    Par défaut Affichage après envoie de donnée d'une page à une autre (avec Ajax)
    Bonjour,

    Je suis assez nouvelle en Django, mais surtout en JS avec Ajax.

    J'ai une première page assez complexe qui va demander de charger des fichiers et qui va se recharger en affichant les données chargées dans des champs qui peuvent être modifié par l'utilisateur. Jusque là pas de soucis et j'utilise js + ajax dans le template pour y arriver.
    Sur cette page j'ai un bouton pour calculer et envoyer les (path) fichiers résultats sur une autre page pour que l'utilisateur puisse les télécharger en local. Et là, je n'ai rien...

    Voici la commande ajax d'envoie :

    Code JavaScript : 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
    $.ajax({
                            url: "/filmchromique/result/",
                            type: "POST",
                            data: formData,
                            processData: false,
                            contentType: false,
                            beforeSend: function (xhr, settings) {
                                xhr.setRequestHeader("X-CSRFToken", $('input[name="csrfmiddlewaretoken"]').val());
                            },
                            success: function(data){
                                console.log(data.protocol_file)
                                $('#protocol_file').html(data.protocol_file);
                                $('#filename').html(data.filename);
                                window.location.href="/filmchromique/result/"
                            },
                            error: function (data, textStatus, jqXHR) {
                                console.log(data)
                            }
     
                        });

    Les différents console sont bons, j'ai bien mes paths dedans

    Voici la vue qui va recevoir la donnée :
    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
     
    class displayResultPage(TemplateView):
        """
        This Function is activate when user click on the launch button of the convertToDose page.
        It receive the request, create the JSON file and launch the ConvertToDose Analysis. Then it redirect to the Result page
        """
        template_name = 'result.html'
        filename = 'None'
        protol_file = 'None'
     
        def get_context_data(self, **kwargs):
            kwargs = super(displayResultPage, self).get_context_data(**kwargs)
            kwargs["filename"] = self.filename
            kwargs["protocol_file"] = self.protol_file
            return kwargs
     
        def post(self, request, *args, **kwargs):
            self.filename = copy.deepcopy(request.POST.get("img_path"))
            self.protol_file = copy.deepcopy(request.POST.get("json_path"))
            context = self.get_context_data(**kwargs)
            #context["filename"] = copy.deepcopy(request.POST.get("img_path"))
            #context["protocol_file"] = copy.deepcopy(request.POST.get("json_path"))
            #kwargs = {
            #    "filename": self.filename,
             #   "protol_file": self.protol_file,
            #}
            return self.render_to_response(context)
    Si j'y vais au débugger pycharm, j'ai un comportement que je ne comprends pas. Il va passer une première fois dans le post qui appelle le get_context_data (je suis bien en request POST). Et là, ma donnée est bien présente dans mon context, tout est parfait. MAIS, avant d'afficher quoique ce soit, il repasse dans cette classe dans le get_context_data (je suis en request GET) et je n'ai absolument rien, comme si il initialisait un nouvel objet. Pourquoi ? Comment faire ?

    Merci
    Images attachées Images attachées  

Discussions similaires

  1. [AJAX] Vérifier des données dans une BDD avec AJAX
    Par mwech dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 22/10/2008, 15h13
  2. [AJAX] ouvrir une page dans une autre avec ajax
    Par msiham05 dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 28/03/2007, 11h27
  3. passer des données a une autre page php
    Par questionneuse dans le forum Langage
    Réponses: 10
    Dernier message: 25/01/2006, 00h56
  4. Réponses: 4
    Dernier message: 01/11/2005, 14h35
  5. [PHP-JS] Envoi de données sur une même page...
    Par dudux dans le forum Langage
    Réponses: 8
    Dernier message: 14/09/2005, 13h51

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