Smarty Forum Index Smarty
WARNING: All discussion is moving to https://reddit.com/r/smarty, please go there! This forum will be closing soon.

Problèmes avec certaines variables

 
This forum is locked: you cannot post, reply to, or edit topics.   This topic is locked: you cannot edit posts or make replies.    Smarty Forum Index -> Language: French
View previous topic :: View next topic  
Author Message
Equinoxe5
Smarty Rookie


Joined: 08 May 2008
Posts: 14

PostPosted: Thu May 08, 2008 9:19 pm    Post subject: Problèmes avec certaines variables Reply with quote

Bonsoir,
Je débute avec smarty depuis 2 jours pour être précis.
J'essaie de refaire mon site perso avec des templates et j'ai ce problème.
Voici un morceau de ma page telle qu'elle était:
Code:
        <?php
        $requete="SELECT categorie, equipe, points, joues, gagnes, perdus, forfaits, sets_plus, sets_moins, points_plus, points_moins FROM classement_des_equipes WHERE categorie='$team' ORDER BY points DESC, (sets_moins/sets_plus) ASC, (points_moins/points_plus) ASC";
        $resultat = mysql_query($requete) or die('Erreur SQL !'.$sql.''.mysql_error());
        $class = mysql_num_rows($resultat);
        $i='0';
   while($row = mysql_fetch_array($resultat))
   {
   $i++;
   $nous="Montigny le Btx";
   if (ereg($nous,$row[equipe])){
           $color="vert";
      $color2="$color";
           }else{
           $color="bleu";
      $color2="$color";
           }
        echo "<tr>";
      echo "<td class='colonne' width='40' align='right'><span class='rouge'>$i&nbsp;</span></td>
         <td class='$color'>&nbsp;$row[equipe]</td>
         <td class='$color' width='70' align='center'><b>$row[points]</b></td>
                        <td class='$color' width='70' align='center'>$row[joues]</td>
                        <td class='$color' width='70' align='center'>$row[gagnes]</td>
         <td class='$color' width='70' align='center'>$row[perdus]</td>";
         if ($row[forfaits] != "0")
         {
         $color="orange";
         }
      echo "<td class='$color' width='70' align='center'>$row[forfaits]</td>";
         $color="$color2";
      echo "<td class='$color' width='70' align='center'>$row[sets_plus]</td>
         <td class='$color' width='70' align='center'>$row[sets_moins]</td>";
      echo "</tr>";
      }}
?>

Dans cet ancien code, j'ai des variables $color, $color2 ainsi qu'une boucle compteur avec une variable $i

Maintenant voici mon nouveau code php

Code:
        $query="SELECT categorie, equipe, points, joues, gagnes, perdus, forfaits, sets_plus, sets_moins, points_plus, points_moins FROM classement_des_equipes WHERE categorie='$team' ORDER BY points DESC, (sets_moins/sets_plus) ASC, (points_moins/points_plus) ASC";
        $result = mysql_query($query) or die('Erreur SQL !'.$sql.''.mysql_error());
        $class = mysql_num_rows($result);
        $i='0';
        $tableau = array();
   while ($resultat = mysql_fetch_object($result))
   {
   $i++;
   $nous="Montigny le Bretonneux";
   if (ereg($nous,$resultat->equipe))            {
           $color='vert';
      $color2='$color';
           }else{
           $color='bleu';
      $color2="$color";
           }
      $tableau[] = array(     
                              'equipe' => $resultat->equipe,
                              'points' => $resultat->points,
                              'joues' => $resultat->joues,
                              'gagnes' => $resultat->gagnes,
                              'perdus' => $resultat->perdus,
                              'forfaits' => $resultat->forfaits,
                         'sets_plus' => $resultat->sets_plus,
                         'sets_moins' => $resultat->sets_moins);
      }}
$smarty->assign('tableau',$tableau);
$smarty->assign('color',$color);
$smarty->assign('color2',$color);
$smarty->assign('maj_class',$maj_class);
$smarty->assign('i',$i);
$smarty->display('class_eq.tpl');
?>

et le template qui va avec
Code:
<p class='alerte'>Classement mis à jour le <u>{$maj_class}</u></p>
<table width='900' class='entoure'>
<tr>
<td class='colonne' width='40' align='center'>Place</td>
<td class='colonne' align='center'>Equipe</td>
<td class='colonne' width='70' align='center'>Points</td>
<td class='colonne' width='70' align='center'>Joués</td>
<td class='colonne' width='70' align='center'>Gagnés</td>
<td class='colonne' width='70' align='center'>Perdus</td>
<td class='colonne' width='70' align='center'>Forfaits</td>
<td class='colonne' width='70' align='center'>Sets +</td>
<td class='colonne' width='70' align='center'>Sets -</td>
</tr>
{foreach from=$tableau item=resultat}
<tr>
<td class='donnees' width='40' align='center'>{$i}</td>
       <td class='{$color}' >{$resultat.equipe}</td>
       <td class='{$color}' align='center' width='70'>{$resultat.points}</td>
       <td class='{$color}' align='center' width='70'>{$resultat.joues}</td>
       <td class='{$color}' align='center' width='70'>{$resultat.gagnes}</td>
       <td class='{$color}' align='center' width='70'>{$resultat.perdus}</td>
       <td class='{$color}' align='center' width='70'>{$resultat.forfaits}</td>
       <td class='{$color}' align='center' width='70'>{$resultat.sets_plus}</td>
       <td class='{$color}' align='center' width='70'>{$resultat.sets_moins}</td>
</tr>
{/foreach}
</table>
{include file='footer.tpl'}


Et mes problèmes sont que je ne récupère pas les valeurs de $color. Tout est de la même couleur soit 'vert' pour toutes mes equipes.
Et ma boucle de numérotation pour le classement me donne toujours la même valeur. Ex: j'obtiens 5 5 5 5 5 au lieu de 1 2 3 4 5.
Quelqu'un peut m'aider svp ?
Merci d'avance
Back to top
View user's profile Send private message
reb
Smarty Rookie


Joined: 17 Aug 2005
Posts: 23

PostPosted: Fri May 09, 2008 7:05 pm    Post subject: Re: Problèmes avec certaines variables Reply with quote

Code:

   while ($resultat = mysql_fetch_object($result))
   {
   $i++;
   $nous=&quot;Montigny le Bretonneux&quot;;
   if (ereg($nous,$resultat-&gt;equipe))            {
           $color='vert';
      $color2='$color';
           }else{
           $color='bleu';
      $color2=&quot;$color&quot;;
           }
      $tableau[] = array(     
                              'equipe' =&gt; $resultat-&gt;equipe,
                              'points' =&gt; $resultat-&gt;points,
                              'joues' =&gt; $resultat-&gt;joues,
                              'gagnes' =&gt; $resultat-&gt;gagnes,
                              'perdus' =&gt; $resultat-&gt;perdus,
                              'forfaits' =&gt; $resultat-&gt;forfaits,
                         'sets_plus' =&gt; $resultat-&gt;sets_plus,
                         'sets_moins' =&gt; $resultat-&gt;sets_moins);
}}
   


Ton $color garde la dernière valeur de ta boucle. Je pense qu'en fait tu voudrais le mettre dans :

Code:
$tableau[] = array(     
                              'equipe' =&gt; $resultat-&gt;equipe,
                              'points' =&gt; $resultat-&gt;points,
                              'joues' =&gt; $resultat-&gt;joues,
                              'gagnes' =&gt; $resultat-&gt;gagnes,
                              'perdus' =&gt; $resultat-&gt;perdus,
                              'forfaits' =&gt; $resultat-&gt;forfaits,
                         'sets_plus' =&gt; $resultat-&gt;sets_plus,
                         'sets_moins' =&gt; $resultat-&gt;sets_moins,
                                        'color' =&gt; $color
);


Idem pour $i.

Il y a pas mal d'optimisation à faire par ailleurs...
Back to top
View user's profile Send private message
Display posts from previous:   
This forum is locked: you cannot post, reply to, or edit topics.   This topic is locked: you cannot edit posts or make replies.    Smarty Forum Index -> Language: French All times are GMT
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


Powered by phpBB © 2001, 2005 phpBB Group
Protected by Anti-Spam ACP