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

AJAX Discussion :

[AJAX] Retourner valeur d'une fonction


Sujet :

AJAX

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Webmaster
    Inscrit en
    Septembre 2013
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Meuse (Lorraine)

    Informations professionnelles :
    Activité : Webmaster
    Secteur : Services à domicile

    Informations forums :
    Inscription : Septembre 2013
    Messages : 3
    Par défaut [AJAX] Retourner valeur d'une fonction
    Bonjour,

    Je souhaite pour un formulaire de commande que je créer pour un site pouvoir récupérer des valeurs qui sont utiliser par divers fonction.

    Voici le fonctionnement du système que je souhaite :

    L'utilisateur sélectionne le revendeur qu'il souhaite (liste déroulante) une fois ce choix fait on fait un appel à la base de donnée pour récupérer la liste des produits (liste déroulante) que ce revendeur fait. Ensuite apparait deux choix à l'utilisateur pour sélectionner entre deux délai et un fois ce délai choisi je fait apparaitre une case pour renseigner la quantité et la je veux pouvoir faire un appel à la base de données pour pouvoir faire un calcul de tarif en fonction des éléments renseigner.

    Maintenant place au code :

    commande.php
    Code php : 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
    28
    <div>
    <script type="text/javascript" src="./commande_xhr.js" charset="iso_8859-1"></script>
    <form action='commande.php' method='POST'> 
    <label for="rev_id">Choix Revendeur (*) :</label>
    <?php 
    $sql = "SELECT rev_societe, rev_id FROM rev, client WHERE rev.rev_valid = 1"; 
    $req = mysql_query($sql);
    ?>
    <select name="rev_id" id="rev_id" onchange="getproduit(this.value);">
    <option value='' selected='selected' disabled='disabled'></option>
    <?php
    while ($data = mysql_fetch_array($req)) 
    {	
    ?>
    <option value="<?php echo $data['rev_id'];  ?>"><?php  echo $data['rev_societe'];  ?></option>
    <?php
    }
    ?>
    <br>
    </select>
    <span id="blocSelectProduit"></span>
    <br>
    <span id="blocSelectDelai"></span>
    <br>
    <span id="blocSelectType"></span>
    <br>
    <span id="blocSelectQuantite"></span>
    </form>


    commande_xhr.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
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    var requete = null;
     
    function creerRequete()
    {
        try
        {
            requete = new XMLHttpRequest();
        }
        catch (microsoft)
        {
            try
            {
                requete = new ActiveXObject('Msxml2.XMLHTTP');
            }
            catch(autremicrosoft)
            {
                try
                {
                    requete = new ActiveXObject('Microsoft.XMLHTTP');
                }
                catch(echec)
                {
                    requete = null;
                }
            }
        }
        if(requete == null)
        {
            alert('Impossible de creer l\'objet requête,\nVotre navigateur ne semble pas supporter les object XMLHttpRequest.');
        }
    }
     
    function actualiserProduits()
    {
        var listeProd = requete.responseText;
        var blocListe = document.getElementById('blocSelectProduit');
        blocListe.innerHTML = listeProd;
    }
     
    function getproduit(idr)
    {
        if(idr == 'vide')
        {
            document.getElementById('blocSelectProduit').innerHTML = '';
        }
        else
        {
            var blocListe = document.getElementById('blocSelectProduit');
            blocListe.innerHTML = "Traitement en cours, veuillez patienter...";
            creerRequete();
            var url = 'commande_produit.php?idr='+ idr;
            requete.open('GET', url, true);
            requete.onreadystatechange = function()
            {
                if(requete.readyState == 4)
                {
                    if(requete.status == 200)
                    {
                        actualiserProduits();
     
                    }
                }
            };
            requete.send(null);
            return idr;
        }
    }
     
    function afficherDelai()
    {
        var listeProd = requete.responseText;
        var blocListe = document.getElementById('blocSelectDelai');
        blocListe.innerHTML = listeProd;
    }
     
    function getdelai(idr2)
    {
        if(idr2 == 'vide')
        {
            document.getElementById('blocSelectDelai').innerHTML = '';
        }
        else
        {
            var blocListe = document.getElementById('blocSelectDelai');
            blocListe.innerHTML = "Traitement en cours, veuillez patienter...";
            creerRequete();
            var url = 'commande_delai.php?idr2='+ idr2;
            requete.open('GET', url, true);
            requete.onreadystatechange = function()
            {
                if(requete.readyState == 4)
                {
                    if(requete.status == 200)
                    {
                        afficherDelai();
                    }
                }
            };
            requete.send(null);
        }
    }
     
    function afficherType()
    {
        var listeProd = requete.responseText;
        var blocListe = document.getElementById('blocSelectType');
        blocListe.innerHTML = listeProd;
    }
     
    function getType(idr3)
    {
        if(idr3 == 'vide')
        {
            document.getElementById('blocSelectType').innerHTML = '';
        }
        else
        {
            var blocListe = document.getElementById('blocSelectType');
            blocListe.innerHTML = "Traitement en cours, veuillez patienter...";
            creerRequete();
            var url = 'commande_type.php?idr3='+ idr3;
            requete.open('GET', url, true);
            requete.onreadystatechange = function()
            {
                if(requete.readyState == 4)
                {
                    if(requete.status == 200)
                    {
                        afficherType();
                    }
                }
            };
            requete.send(null);
        }
    }
     
    function afficherQuantite()
    {
        var listeProd = requete.responseText;
        var blocListe = document.getElementById('blocSelectQuantite');
        blocListe.innerHTML = listeProd;
    }
     
    function getQuantite(idr4)
    {
        if(idr4 == 'vide')
        {
            document.getElementById('blocSelectQuantite').innerHTML = '';
        }
        else
        {
            var blocListe = document.getElementById('blocSelectQuantite');
            blocListe.innerHTML = "Traitement en cours, veuillez patienter...";
            creerRequete();
            var url = 'commande_quantite.php?idr4='+ idr4;
            requete.open('GET', url, true);
            requete.onreadystatechange = function()
            {
                /* Lorsque l'etat est a 4 */
                if(requete.readyState == 4)
                {
                    /* Si on a un statut a 200 */
                    if(requete.status == 200)
                    {
                        afficherQuantite();
                    }
                }
            };
            requete.send(null);
        }
    }
     
    function afficherMontant()
    {
        var listeProd = requete.responseText;
        var blocListe = document.getElementById('blocSelectQuantite');
        blocListe.innerHTML = listeProd;
    }
     
    function getMontant(idr5)
    {
        if(idr5 == 'vide')
        {
            document.getElementById('blocSelectQuantite').innerHTML = '';
        }
        else
        {
            var blocListe = document.getElementById('blocSelectQuantite');
            blocListe.innerHTML = "Traitement en cours, veuillez patienter...";
            creerRequete();
            var url = 'commande_montant.php?idr5='+ idr5;
            requete.open('GET', url, true);
            requete.onreadystatechange = function()
            {
                if(requete.readyState == 4)
                {
                    if(requete.status == 200)
                    {
                        afficherMontant();
                    }
                }
            };
            requete.send(null);
        }
    }
    //calcul montant en fonction de la quantite
    function afficherMontantCalcul()
    {
        var listeProd = requete.responseText;
        var blocListe = document.getElementById('blocCalcul');
        blocListe.innerHTML = listeProd;
    }
     
    function calculMontant(idr6)
    {
        if(idr6 == 'vide')
        {
            document.getElementById('blocCalcul').innerHTML = '';
        }
        else
        {
            var blocListe = document.getElementById('blocCalcul');
            blocListe.innerHTML = "Traitement en cours, veuillez patienter...";
            creerRequete();
            var url = 'commande_calcul_montant.php?idr6='+ idr6;/
            requete.open('GET', url, true);
            requete.onreadystatechange = function()
            {
                if(requete.readyState == 4)
                {
                    if(requete.status == 200)
                    {
                        afficherMontantCalcul();
                    }
                }
            };
            requete.send(null);
        }
    }
    Je vous épargne pour le moment le reste du code (fichier php appeler par les fonction JS qui me serve à récupérer les valeurs dans la base ou alors le code html du bloc suivant en fonction de la selection)


    Mon souhait est de pouvoir récupérer dans la fonction "calculMontant" la valeur de la fonction "getproduit(idr)" par exemple.

    Je prends tout même juste une idée.
    Merci d'avance de votre aide en espérant avoir été assez clair.

    Mimil5

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2013
    Messages
    141
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2013
    Messages : 141
    Par défaut
    Salut,

    Je ne vois pas ou est ton problème étant donnée que ta valeur idr est au départ une variable que tu a bien dù déclarer quelque part, si celle-ci est bien déclarer dans une fonction il te suffit alors de passer ta variable en global ainsi tu pourra récupérer celle-ci ou tu veut dans ton code et donc récupérer sa valeur n'importe ou.

    Si ce n'est pas un problème de variable global alors je n'ai pas compris ton problème désolé.

  3. #3
    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 : 55
    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
    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

  4. #4
    Futur Membre du Club
    Homme Profil pro
    Webmaster
    Inscrit en
    Septembre 2013
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Meuse (Lorraine)

    Informations professionnelles :
    Activité : Webmaster
    Secteur : Services à domicile

    Informations forums :
    Inscription : Septembre 2013
    Messages : 3
    Par défaut
    Merci Tendhor57

    en faisant passer en variable globale je peux maintenant utiliser dans plusieurs fonction mes variable et ainsi gérer les choix fait au cas par cas

Discussions similaires

  1. Réponses: 3
    Dernier message: 08/08/2010, 23h12
  2. Retourner plusieurs valeurs a une fonction ajax
    Par Hyuge dans le forum jQuery
    Réponses: 2
    Dernier message: 11/06/2009, 15h49
  3. [AJAX] recuperer plusieurs valeurs dans une fonction
    Par tortue_22 dans le forum AJAX
    Réponses: 4
    Dernier message: 17/05/2009, 13h48
  4. retourné un tableau de valeur d'une fonction
    Par hoaxpunk dans le forum Oracle
    Réponses: 2
    Dernier message: 24/01/2006, 17h36
  5. Retourner une valeur avec une fonction
    Par stephtbest dans le forum ASP
    Réponses: 4
    Dernier message: 31/10/2003, 16h37

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