0

问题:

在不使用任何 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 循环中添加什么以便它识别最后一行并打印不同的代码?

4

2 回答 2

3

使用计数器:

$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
  }
}
于 2012-06-17T05:37:46.183 回答
0

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

  1. 使用 :last-child (但这在 IE8 中不起作用)

    表 tr:last-child { 背景颜色:#ff0000; }​</p>

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

在文档加载功能中,添加以下 jQuery 代码,

$("td:last-child").css({background-color:"#ff0000"})
于 2012-06-17T05:42:13.733 回答