[英]Set different row table color basis on performance
我正在用SQL記錄學生的成績。 只有2列。
sl no. Name Points
1 Admam 89
2 Russel 86
3 Andy 79
4 Lance 76
5 Steve 75
6 jack 74
7 Phil 70
8 mark 67
9 kevin 65
10 andrew 65
11 brian 64
12 pat 63
這是SQL報告格式。我需要為每3個學生上色表格。對於前3個學生(1、2、3),它們被稱為“鑽石”,因此3行需要為灰色上色。 接下來的3個學生(4,5,6)被稱為“白金”,因此3行需要塗成綠色。
但是在下一行中,Phi,Mark和Kevin需要將顏色塗成黃色。 但是安德魯也因為同樣的觀點而加入了凱文。 所以現在4行應該變成黃色..請讓我知道該怎么做....
看看這個小提琴phpfiddle
<?php
$points=array(1,1,1,2,2,3,3,3,3);
$color= array(1=>'red',2=>'green',3=>'yellow');
?>
<table width="100%">
<?php
foreach($points as $key=>$grade)
{?>
<tr>
<td style="color:<?php if( $key!=0 && $points[$key]!=$points[$key-1] )
{echo $color[$grade];} else{ if(($key+1)%3==0)
{ echo $color[$grade];} else {echo $color[$grade];} } ?>">
student <?php echo $key; ?></td>
</tr>
<?php }?>
</table>
為每個范圍點使用一種顏色
$colors = array(
1 => 'grey',
2 => 'green',
3 => 'yellow',
4 => 'black'
);
$i = 0;
$color_id = 0;
$lastpoint = -1;
foreach($students as $id=>$student) {
$color_id += ($i % 3 == 0 && $student['point'] != $lastpoint) ? 1 : 0;
$lastpoint = $student['point'];
?>
<tr>
<td style="color:<?php echo colors[$color_id];?>";>
<?php echo $student['name']; ?>
</td>
</tr>
<?php
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.