|
Smarty
WARNING: All discussion is moving to https://reddit.com/r/smarty, please go there! This forum will be closing soon. |
|
View previous topic :: View next topic |
Author |
Message |
Equinoxe5 Smarty Rookie
Joined: 08 May 2008 Posts: 14
|
Posted: Thu May 08, 2008 9:19 pm Post subject: Problèmes avec certaines variables |
|
|
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 </span></td>
<td class='$color'> $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 |
|
reb Smarty Rookie
Joined: 17 Aug 2005 Posts: 23
|
Posted: Fri May 09, 2008 7:05 pm Post subject: Re: Problèmes avec certaines variables |
|
|
Code: |
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);
}}
|
Ton $color garde la dernière valeur de ta boucle. Je pense qu'en fait tu voudrais le mettre dans :
Code: | $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,
'color' => $color
); |
Idem pour $i.
Il y a pas mal d'optimisation à faire par ailleurs... |
|
Back to top |
|
|
|
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
|
|