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] Envoi d'une variable Javascript vers php en MVC


Sujet :

AJAX

  1. #1
    Membre r�gulier
    Homme Profil pro
    Inscrit en
    Janvier 2014
    Messages
    9
    D�tails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2014
    Messages : 9
    Par d�faut [AJAX] Envoi d'une variable Javascript vers php en MVC
    Bonjour,

    �a fait un moment que je bloque sur ce probl�me.
    Plus pr�cis�ment, je r�cup�re une variable de type tableau en Javascript dans ma Vue.
    J'aimerais envoyer cette variable dans mon Controller puis vers vers le Model qui sont tous deux en Php.
    Pour ce faire j'utilise l'objet getXMLHttpRequest():

    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
     
    <input type="button" id="b2012 " class="buttonTab" value="2012" onclick="myFunction()"> 
     
    <script>
     
    function myFunction() {
          var sVar1 = ‘ bonjou r’;
          var sVar2 = ‘Antoine ‘; 
          xhr = getXMLHttpRequest(); 
          xhr.onreadystatechange = function() {
    		if (xhr.readyState == 4 && (xhr.status == 200 || xhr.status == 0)) {
    			document.getElementById("b2012").innerHTML = xhr.responseText;
    		}
          };
          xhr.open("GET", "../controller?&variable1= " + sVar1 + "&variable2= " + sVar2, true);
          xhr.send(null);
    }
     
    </script>
    Et dans le controller je fais un Get pour r�cup�rer me variables, puis je les renvois dans mon Model.
    Malheureusement il y a un souci au niveau de l'envoie, je r�cup�re une variable vide et il y a chargement du footer/vue/header du controller.

    �a fait une semaine que je cherche donc j'ai pu regarder sur pas mal de forums les solutions, mais je n'ai rien trouv� de cas similaire au mien.
    J'avoue avoir un peu de mal � comprendre l'Ajax et l'interaction client/serveur mais je bouquine l� dessus. Si quelqu'un pouvait m'�clairer ce serait g�nial.

  2. #2
    Membre Expert Avatar de nathieb
    Homme Profil pro
    DevOps
    Inscrit en
    Mai 2004
    Messages
    1 058
    D�tails du profil
    Informations personnelles :
    Sexe : Homme
    �ge : 58
    Localisation : France, Paris (�le de France)

    Informations professionnelles :
    Activit� : DevOps
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 058
    Par d�faut Architecture MVCBonjour,
    Bonjour,

    Je en sais pas quel Framework tu utilises pour ton d�veloppement PHP, mais si on se base sur
    du standard MVC, quand tu fais un appel ajax, tu appelles ton controller principal, avec l'action sous jacente.
    Dans cette derni�re tu dois shunter la r�cup�ration de la vue, car dans les frameworks MVC, l'appel de la vue
    est sous entendue.

    tu dois forcer l'encodage de la r�ponse en json, et faire un return de quelque chose autre que ta vue


    Olivier

  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
    Par d�faut
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    var sVar1 = ‘ bonjou r’;
    var sVar2 = ‘Antoine ‘;
    Tes variables sont r�ellement d�clar�es comme �a dans ton code ?
    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
    Membre r�gulier
    Homme Profil pro
    Inscrit en
    Janvier 2014
    Messages
    9
    D�tails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2014
    Messages : 9
    Par d�faut
    @Nathieb:

    En effet, j'avais oublier de pr�ciser que j'utilise CodeIgniter comme FrameWork.
    Merci, je vais essayer d'appliquer ce que vous m'avez indiquer et je vous tiens au courant si je rencontre d'autres difficult�s.
    Qu'entendez-vous par shunter?

    @Bovino:

    Non, mon vrai code est un peu moins bord�lique, ce qui m'importait c'�tait de vous expliquer mon probl�me et d'avoir une m�thode pour le r�soudre.

  5. #5
    Mod�rateur

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

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 211
    Par d�faut
    Bonjour,
    Non, mon vrai code est un peu moins bor...
    je pense que Bovino faisait allusion au quote utilis� dans la d�claration de tes chaines.

  6. #6
    Membre Expert Avatar de nathieb
    Homme Profil pro
    DevOps
    Inscrit en
    Mai 2004
    Messages
    1 058
    D�tails du profil
    Informations personnelles :
    Sexe : Homme
    �ge : 58
    Localisation : France, Paris (�le de France)

    Informations professionnelles :
    Activit� : DevOps
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 058
    Par d�faut shunter le controller
    Bonjour,

    J'ai trouv� cet exemple, c'est ce qu'on appelle "shunter", ou si tu veux changer le retour du controleur.

    http://stackoverflow.com/questions/1...rom-controller

    Olivier

  7. #7
    Membre r�gulier
    Homme Profil pro
    Inscrit en
    Janvier 2014
    Messages
    9
    D�tails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2014
    Messages : 9
    Par d�faut
    @NoSmoking

    D'accord, je re-�dite mon code:
    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
     
     
    <input type="button" id="b2012 " class="buttonTab" value="2012" onclick="myFunction()"> 
     
    <script>
     
    function myFunction() {
          var sVar1 = "bonjour";
          var sVar2 = "Antoine"; 
          xhr = getXMLHttpRequest(); 
          xhr.onreadystatechange = function() {
    		if (xhr.readyState == 4 && (xhr.status == 200 || xhr.status == 0)) {
    			document.getElementById("b2012").innerHTML = xhr.responseText;
    		}
          };
          xhr.open("GET", "../controller?&variable1= " + sVar1 + "&variable2= " + sVar2, true);
          xhr.send(null);
    }
     
    </script>
    @Nathieb

    Merci, pour l'explication. Je vais appliquer ceci � mon code et trifouiller pour que �a marche.

  8. #8
    Membre Expert Avatar de nathieb
    Homme Profil pro
    DevOps
    Inscrit en
    Mai 2004
    Messages
    1 058
    D�tails du profil
    Informations personnelles :
    Sexe : Homme
    �ge : 58
    Localisation : France, Paris (�le de France)

    Informations professionnelles :
    Activit� : DevOps
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 058
    Par d�faut debug
    Bonjour,

    Quand j'utilise de l'ajax j'utilise firebug, il te permet de voir les allez retour de tes requ�tes.
    Au moins tu sais ce qui se passe mais je pense que tu l'utilises d�j� ?

    Olivier

  9. #9
    Mod�rateur

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

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 211
    Par d�faut
    <input type="button" id="b2012 " class="buttonTab" value="2012" onclick="myFunction()">
    compte tenu que tu veux modifier le innerHTML d'un INPUT type=button cela ne m'�tonne pas que tu ne visualises pas le r�sultat
    Code : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    if (xhr.readyState == 4 && (xhr.status == 200 || xhr.status == 0)) {
        document.getElementById("b2012").innerHTML = xhr.responseText;
    }

  10. #10
    Membre r�gulier
    Homme Profil pro
    Inscrit en
    Janvier 2014
    Messages
    9
    D�tails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2014
    Messages : 9
    Par d�faut
    J'ai r�ussi � envoyer ma variable dans le controller, alors ce que j'ai fais:

    Dans la vue:
    Code html : S�lectionner tout - Visualiser dans une fen�tre � part
    <input type="button" id="b2012" ?>" class="buttonTab" value="2012" onclick="date_selected();">

    Donc onclick j'applique la fonction "date_selected()":

    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 dates_selected() { //récupère les dates sélectionnés dans un tableau  
           var tab = new Array("donnée 1", "donnée 2", "donnée 3", "donnée 4");
    	scriptName = "http://localhost/.../index.php/c_consultation/recupvar";
    	var xhr_object = null;                                      
    	// ### Construction de l’objet XMLHttpRequest selon le type de navigateur
    	// Cas des navigateurs de type Netscape (Firefore, Conqueror, etc.)
    	if(window.XMLHttpRequest)  xhr_object = new XMLHttpRequest(); // Cas du navigateur Internet Explorer
    	else if(window.ActiveXObject) xhr_object = new ActiveXObject("Microsoft.XMLHTTP"); // Cas des navigateurs ne comprenant pas cette technologie (anciens navigateurs)
    	else{
    	    // XMLHttpRequest non supporté par le navigateur
    	    alert("Votre navigateur ne supporte pas les objets XMLHTTPRequest...");
    	    return;
    	}   
    	// Fin construction de l’objet XMLHttpRequest
    	xhr_object.open("POST", scriptName, true); //  Définition du comportement à adopter sur le changement d’état de l’objet
    	// XMLHttpRequest
    	xhr_object.onreadystatechange = function(){
    	    // Etat : requête terminée, réponse récupérée
    	    if(xhr_object.readyState == 4){
    		document.write(xhr_object.responseText);
    	    }
    	    return xhr_object.readyState;
    	}
    	xhr_object.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
    	xhr_object.send("latlng="+args);//je fais l envoi a php ici
    }
    Je r�cup�re ainsi ma variable tab dans le fonction recupvar de mon controller comme ceci:

    Code php : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    class c_consultation extends CI_Controller {
    	public function recupvar(){
    	      $variable1 = array();
    	      if((isset($_POST["latlng"]))&&(!empty($_POST["latlng"]))){
    		  $variable1 = $_POST["latlng"];
    	      }
    	      else{
    		      echo "FAIL";
    	      }
    	     return $variable1;
    	}

    Ensuite je veux envoyer cette variable vers mon mod�le pour qu'elle change la valeur dans mon tableau comme �a:

    Code php : S�lectionner tout - Visualiser dans une fen�tre � part
    1
    2
    3
    $annee = $this->recupvar();					
    $this->load->model('m_model');
    $data['tab'] = $this->m_model->consult_un($annee);

    Et ce code me renvoie une page blanche. Je ne dois pas avoir la bonne m�thode pour shunter la vue...
    Je continue mes recherches.

Discussions similaires

  1. Transfert d'une variable JavaScript vers PHP
    Par iparcos dans le forum G�n�ral JavaScript
    R�ponses: 1
    Dernier message: 20/11/2015, 17h46
  2. R�cup�rer une variable javascript vers php sans formulaire
    Par NewDew dans le forum G�n�ral JavaScript
    R�ponses: 9
    Dernier message: 27/10/2015, 13h53
  3. [PHP-JS] recuperer une variable javascript dan php
    Par hammag dans le forum Langage
    R�ponses: 2
    Dernier message: 07/08/2006, 14h00
  4. [PHP-JS] Transmettre une variable javascript vers php
    Par phpaide dans le forum G�n�ral JavaScript
    R�ponses: 11
    Dernier message: 20/05/2006, 08h30
  5. [PHP-JS] variable javascript vers PHP
    Par nicoaix dans le forum Langage
    R�ponses: 3
    Dernier message: 17/03/2006, 21h28

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