查找foreach查询中的最后一行

时间:2013-07-14 17:48:43

标签: php mysql

我怎样才能找到最后一篇文章而不将<hr>放在它下面?

<?php foreach($db->query("SELECT * FROM news") as $row): ?>
<div class="NewsHeadline">
<div class="NewsDate"><?php echo $date; ?> - </div>
<div class="NewsTitle"><?php echo $title; ?></div>
</div>

<div class="NewsBody">
<?php echo $body; ?>
</div>

<hr>
<?php endforeach ?>

4 个答案:

答案 0 :(得分:2)

设置一个等于1的计数器,每轮递增一次,并检查它是否等于返回的$ query数组的count()。如果是,你就是最后一轮!

<?php 
    $counter = 1; 
    $total = count($db->query("SELECT * FROM news"));
?>
<?php foreach($db->query("SELECT * FROM news") as $row): ?>
    <div class="NewsHeadline">
        <div class="NewsDate"><?php echo $date; ?> - </div>
        <div class="NewsTitle"><?php echo $title; ?></div>
    </div>

    <div class="NewsBody">
        <?php echo $body; ?>
    </div>
    <?php if($counter != $total){
    ?>
        <hr>
    <?php
    }

   ?>

<?php $counter++; ?>
<?php endforeach ?>

答案 1 :(得分:2)

解决方案是构建一个数组,然后使用join

<?php
$arr=array();
foreach($db->query("SELECT * FROM news") as $row):
    $arr[] = '<div class="NewsHeadline"><div class="NewsDate">'.$date
        .' - </div><div class="NewsTitle">'.$title'
        .</div></div><div class="NewsBody">'.$body.'</div>';
endforeach
echo join("<hr>",$arr);    
?>

答案 2 :(得分:1)

您可以转换为常规for循环,然后将$ i与查询结果的大小进行比较:

<?php 
    $news = $db->query("SELECT * FROM news");

    for($i=0; $i<sizeof($news);$i++){ ?>
        <div class="NewsHeadline">
            <div class="NewsDate"><?php echo $date; ?> - </div>
            <div class="NewsTitle"><?php echo $title; ?></div>
        </div>

        <div class="NewsBody">
            <?php echo $body; ?>
        </div>

        <?php if(($i+1) < sizeof($news)) echo '<hr>'; ?> 
<?php } ?>

答案 3 :(得分:0)

如果在循环之前得到行的计数,则可以检查计数并避免添加HR。

$rows = $db->query("SELECT * FROM news");
$row_count = $rows.count();
$iter = 0;
foreach($rows as $row) 
{
   //...
   if ($iter < $row_count)
   {
        // render hr
   }
   $iter++;
 }

你也可以使用纯CSS方法:

div.containerClass:last-child hr { display:none; }

其中&#34; containerClass&#34;将是您发布的代码所在的任何元素。

相关问题