Passer une variable en Javascript

TRUNCKS Messages postés 1066 Statut Membre -  
TRUNCKS Messages postés 1066 Statut Membre -
Bonjour à vous,

J'aimerai faire passer une variable php si jamais un onclick Javascript est validé.

Par exemple, quand je clique sur mon lien qui déclenche le onclick, ma variable php passe à "ok".
Car j'ai besoin de cette variable test pour lancer une autre partie du script si jamais elle est ok.

J'aimerai savoir si c'est possible.

Merci à vous

9 réponses

  1. Alain_42 Messages postés 5413 Statut Membre 904
     
    ou une autre solution:

    tu mets dans un form, un champ caché
    <input type="hidden" name="ma_variable" id="ma_variable" value="" />


    sur le onclick tu lances une fonction javascript qui contient:

    document.getElementById('ma_variable').value="ok"


    lorsque le formulaire sera posté vers le serveur pour appeler le script php tu auras ainsi la valeur récupérable dans $_POST['ma_variable']
    1
  2. TRUNCKS Messages postés 1066 Statut Membre 8
     
    Merci pour vos réponses :)

    Alors en fait j'ai ce bout de javascript qui gère l'affichage d'un popup:

    <!-- include jQuery library -->
    <script type="text/javascript" src="js/jquery.js"></script>
    <!-- include Cycle plugin -->
    <script type="text/javascript" src="js/jquery.cycle.all.latest.js"></script>
    <script type="text/javascript">
    $(document).ready(function() {
        $('.slideshow').cycle({
    		fx: 'fade' // choose your transition type, ex: fade, scrollUp, shuffle, etc...
    	});
    });
    </script>
    
    <script type="text/javascript">
    
    var ns4=document.layers
    var ie4=document.all
    var ns6=document.getElementById&&!document.all
    
    //drag drop function for NS 4////
    /////////////////////////////////
    
    var dragswitch=0
    var nsx
    var nsy
    var nstemp
    
    function drag_dropns(name){
    if (!ns4)
    return
    temp=eval(name)
    temp.captureEvents(Event.MOUSEDOWN | Event.MOUSEUP)
    temp.onmousedown=gons
    temp.onmousemove=dragns
    temp.onmouseup=stopns
    }
    
    function gons(e){
    temp.captureEvents(Event.MOUSEMOVE)
    nsx=e.x
    nsy=e.y
    }
    function dragns(e){
    if (dragswitch==1){
    temp.moveBy(e.x-nsx,e.y-nsy)
    return false
    }
    }
    
    function stopns(){
    temp.releaseEvents(Event.MOUSEMOVE)
    }
    
    //drag drop function for ie4+ and NS6////
    /////////////////////////////////
    
    
    function drag_drop(e){
    if (ie4&&dragapproved){
    crossobj.style.left=tempx+event.clientX-offsetx
    crossobj.style.top=tempy+event.clientY-offsety
    return false
    }
    else if (ns6&&dragapproved){
    crossobj.style.left=tempx+e.clientX-offsetx+"px"
    crossobj.style.top=tempy+e.clientY-offsety+"px"
    return false
    }
    }
    
    function initializedrag(e){
    crossobj=ns6? document.getElementById("showimage") : document.all.showimage
    var firedobj=ns6? e.target : event.srcElement
    var topelement=ns6? "html" : document.compatMode && document.compatMode!="BackCompat"? "documentElement" : "body"
    while (firedobj.tagName!=topelement.toUpperCase() && firedobj.id!="dragbar"){
    firedobj=ns6? firedobj.parentNode : firedobj.parentElement
    }
    
    if (firedobj.id=="dragbar"){
    offsetx=ie4? event.clientX : e.clientX
    offsety=ie4? event.clientY : e.clientY
    
    tempx=parseInt(crossobj.style.left)
    tempy=parseInt(crossobj.style.top)
    
    dragapproved=true
    document.onmousemove=drag_drop
    }
    }
    document.onmouseup=new Function("dragapproved=false")
    
    ////drag drop functions end here//////
    
    function hidebox(){
    crossobj=ns6? document.getElementById("showimage") : document.all.showimage
    if (ie4||ns6)
    crossobj.style.visibility="hidden"
    else if (ns4)
    document.showimage.visibility="hide"
    }
    
    </script>
    


    Et mon php qui l'affiche, et qui est fait, que j'aimerai modifier pour pouvoir par exemple, ne pas pouvoir ouvrir un autre popup sans d'abord fermé celui en cours.

    <?php
    
    while ($result_news = mysql_fetch_array($retour_news)){
    	
    $i = $result_news['ID_news'];
    	
    ?>
    
    <span style="margin:10px;">
    <a href="javascript:void(0)" style="text-decoration:none; color:black;" onClick="javascript&#058; document.getElementById('showimage<?php echo $i; ?>').style.display='block';"><span style="font-size:16px;"><strong><?php echo html_entity_decode($result_news['titre']);?></strong></span> - <span style="font-size:12px;"><?php echo $result_news['date_fr'];?></span></a>
    <hr />
    </span>
    
    <div id="showimage<?php echo $i; ?>" style="position:absolute; width: 12em; left:45%; margin-left: -220px; height: 8em; top: 50%; display:none; z-index:10;">
    
    <table border="0" width="600" bgcolor="#D04502" cellspacing="0" cellpadding="2">
    <tr>
    <td width="100%"><table border="0" width="100%" cellspacing="0" cellpadding="0">
    <tr>
    <td id="dragbar" style="cursor:hand; cursor:pointer" height="40" width="100%" onMousedown="initializedrag(event)"><ilayer width="100%" onSelectStart="return false"><layer width="100%" onMouseover="dragswitch=1;if (ns4) drag_dropns(showimage)" onMouseout="dragswitch=0"><font face="Verdana" color="#FFFFFF"><strong><small><span style="margin-left:10px; margin-right:10px;"><?php echo html_entity_decode($result_news['titre']);?></span></small></strong></font></layer></ilayer></td>
    <td style="cursor:hand"><a href="javascript:void(0)" onClick="javascript&#058; document.getElementById('showimage<?php echo $i; ?>').style.display='none';"><img src="images/close.gif" width="16px" height="14px" border=0></a></td>
    </tr>
    <tr>
    <td stwidth="100%" height="200" bgcolor="#FFFFFF" style="padding:4px" colspan="2">
    
    <!-- PUT YOUR CONTENT BETWEEN HERE -->
    
    <div style="margin-left:10px; margin-right:10px; text-align:justify;">
    
    <span style="font-size:16px;"><strong><?php echo html_entity_decode($result_news['titre']);?></strong></span> - <span style="font-size:12px;"><?php echo $result_news['date_fr'];?></span></a>
    <br /><br />
    
    <?php echo html_entity_decode($result_news['texte']);?>
    
    <!-- END YOUR CONTENT HERE -->
    </div>
    
    </td>
    </tr>
    </table>
    </td>
    </tr>
    </table>
    
    </div>
    
    <?php
    }
    ?>
    </div>
    
    1
  3. TRUNCKS Messages postés 1066 Statut Membre 8
     
    --Merci pour la réponse !
    Donc du coup ce n'est pas possible sans faire passer une variable en url ?
    0
    1. Fallentree Messages postés 2445 Statut Membre 210
       
      onclick="javascript: alert('<?php $tmp="une variable"; echo $tmp; ?>');"
      0
    2. dariumis Messages postés 583 Statut Membre 63
       
      non, c'est pas possible a moins de faire de l'ajax, le javascript étant executer coté client et le php coté serveur tu es obligé de rafraichir ta page pour effectuer un traitement php.
      0
    3. dariumis Messages postés 583 Statut Membre 63
       
      Ou je me suis planté, tu veux faire php -> vers javascript, ou javascript -> vers php??
      0
    4. Fallentree Messages postés 2445 Statut Membre 210
       
      Mille escuses...
      J'avais pas bien lu...
      Mais tu peux peut etre t en sortir avec une Iframe ...
      Tu codes pour que l iframe change de Src avec les parametres qui te permettent de tes variables ..
      0
  4. Vous n’avez pas trouvé la réponse que vous recherchez ?

    Posez votre question
  5. TRUNCKS Messages postés 1066 Statut Membre 8
     
    Merci pour ces réponses,

    En fait j'aimerai quand en cas de onclick, une variable php prenne "Ok"

    Je ne connais pas cette solution iframe, il est possible de détailler ou de me rediriger vers un tuto ?

    Dans tous les cas, merci pour votre patience
    0
    1. Fallentree Messages postés 2445 Statut Membre 210
       
      c est pas un gestionare de formulaire que tu cherches a faire ...
      une fois validé tu as fichier.php?Ok
      0
  6. TRUNCKS Messages postés 1066 Statut Membre 8
     
    Non en fait j'aimerai tout simplement, une fois cliqué sur "onclick" que ma variable se mette en ok.

    Et me resservir de ce ok dans une autre partie du script.
    0
    1. Fallentree Messages postés 2445 Statut Membre 210
       
      <?php
      $Ok='false';
      if (sizeof($_GET)>0){
      if (isset($_GET['Ok']))
      $Ok='true';
      if ($_GET['Ok']=='false') $Ok='false';
      echo "ma valeur est ".$Ok;
      }
      ?>
      <body bgcolor="#FFFFFF">
      <script type="text/javascript">
      var temoin =<?php if ($Ok==false) echo 'false'; else echo 'true';?>;

      window.onload=function ( ) {
      document.getElementsByName('Ok')[0].value=temoin;
      document.getElementsByName('valid form')[0].value='temoin='+temoin;};


      function affiche() {
      if (temoin==true) {
      temoin=false;
      document.getElementById('iframe').style.visibility='hidden';
      }
      else {
      temoin=true;
      document.getElementById('iframe').style.visibility='visible';
      document.getElementById('iframe').src='test iframe.php?Ok'; }
      document.getElementsByName('Ok')[0].value=temoin;
      document.getElementsByName('valid form')[0].value='temoin='+temoin;
      }
      </script>
      <form name="test" method="get">
      <input type="hidden" name="Ok" />
      <input type="submit" name="valid form" />
      </form>
      <input type="submit" onclick="affiche();" name="charge_value" />
      <hr>
      <iframe style="visibility:hidden;" width="600" height="400" id="iframe"></iframe>
      </body>

      </html>
      0
    2. Fallentree Messages postés 2445 Statut Membre 210
       
      si ca peux t 'aider ...
      0
  7. TRUNCKS Messages postés 1066 Statut Membre 8
     
    Merci d'avoir pris la peine de m'aider, mais mon niveau en Javascript est vraiment très nul.

    J'ai fait un copier coller mais je n'ai pas vraiment compris l'idée de l'exemple.
    Pardonnez moi :(

    Je clique et ça me remet les mêmes boutons.
    0
  8. Alain_42 Messages postés 5413 Statut Membre 904
     
    un exemple plus concret:
    <html> 
    <script type="text/javascript"> 
     function passer_valeur(valeur){ 
      document.getElementById('ok').value=valeur; 
        
     } 
    </script> 
    <body> 
    <?php 
    //init variables par defaut 
    $ok=false; 
    if(issset($_POST['envoyer')){ 
     //le formulaire a été posté  
     //recup valeur de ok 
     $ok=$_POST['ok']; 
    } 
    if($ok==false){ 
     ?> 
     <form name="form1" method="post" action=""> 
     <input type="hidden" name="ok" id="ok" value="" /> 
     Avez vous bu un café ce matin ? <br /> 
     <input type="button" name="bouton1" value="Oui" onclick="passer_valeur('oui');" /> 
     <input type="button" name="bouton2" value="Non" onclick="passer_valeur('non');" /> <br /><br />
     <input type="submit" name="envoyer" value="Envoyer" /> 
     </form> 
     <?php 
    }else{ 
     if($ok=='oui') echo 'Vous avez bu votre café !'; 
     if($ok=='non') echo 'Vous n\'avez pas bu votre café !'; 
      
    
    } 
    ?> 
    </body> 
    
    </html>
    0
    1. Fallentree Messages postés 2445 Statut Membre 210
       
      on peut rajouter un parent javascript pour sa variable php
      Mais je ne comprends pas pourquoi il veut qu elle change...
      Si elle n'est pas lier a la session, elle ne vit que le temps de l'appel ...
      Bref $ok est peut etre une source issue d'un calcul ...
      0
  9. Fallentree Messages postés 2445 Statut Membre 210
     
    Fais nous un rebus de code pour voirTRUNCKS ...
    0