使用 PHP 的最后一个 SQL 行上的不同 CSS 样式


Different CSS style on last SQL row using PHP

问题:

在不使用任何 CSS3 选择器的情况下设置 SQL 查询中最后一行的样式。

PHP代码:

while ($item = mysql_fetch_assoc($itemsresult))
{
    $answer = "SELECT IID, Comment FROM betyg_answers WHERE EID = '{$EID}' AND CID = '{$item['CID']}' ORDER BY ID ASC";
    $answerresult = mysql_query($answer) or die ('Error (' . mysql_errno() . ') ' . mysql_error());
    $answer = mysql_fetch_assoc($answerresult);
    if ($answer['IID'] == $item['IID'])
    {
        $html .= '
            <tr>
                <td class="arrow" style="'.$arrow.'"><img src="./img/circle_arrow_right.png" class="arrowimage"></td>
                <td class="numbers" style="'.$numbers.'">'.$itemcounter.'.</td>
                <td class="text" style="'.$text.'">'.$item['Description'].'</td>
            </tr>
        ';
    }
    else
    {
        $html .= '
            <tr>
                <td class="arrow" style="'.$arrow.'">&nbsp;</td>
                <td class="numbers" style="'.$numbers.'">'.$itemcounter.'.</td>
                <td class="text" style="'.$text.'">'.$item['Description'].'</td>
            </tr>
        ';
    }
    $itemcounter++;
}

SQL 查询中的最后一行应改为打印:

$html .= '
        <tr>
            <td class="arrow" style="'.$lastarrow.'">&nbsp;</td>
            <td class="numbers" style="'.$lastnumbers.'">'.$itemcounter.'.</td>
            <td class="text" style="'.$lasttext.'">'.$item['Description'].'</td>
        </tr>
';

问题:

在 while 循环中添加什么才能识别最后一行并打印不同的代码?

使用计数器:

$i = 0;
$c = mysql_num_rows($itemresult);
while ($item = mysql_fetch_assoc($itemsresult)) {
  $i++;
  if ($i == $c) {
    // This is a last row
  } else {
    // Regular row
  }
}

几种方法可以做到这一点:

  1. 使用 :最后一个孩子(但这在 IE8 中不起作用)

    表 tr:最后一个子项 {背景颜色:#ff0000;}

  2. 使用jQuery方法(这是独立于浏览器的)

在文档加载函数中,添加以下 jQuery 代码,

$("td:last-child").css({background-color:"#ff0000"})