0

我的回显结果有分页系统但是,页码在彼此下方回显

例如

                              1
                2 3 4 5

这是我的代码:

for($i=0;$i < $count1;$i=$i+$limit)
 {
if($i <> $start)
{       
    echo "<a href='view.php?search=$search&start=$i&limit=$limit&price=$price&category=$category'><font face='Verdana' size='2'><b>&nbsp;$l&nbsp;</b></font></a> ";
}
else
{
    echo "<center><font face='Verdana' size='4' color=#2E9AFE ><b>&nbsp;$l&nbsp;</b></font></center>";
}        

修改后的代码:

$i=0;
 $l=1;
   echo "<p align='left'>";
   for($i=0;$i < $count1;$i=$i+$limit)
   {
  if($i <> $start)
   {        
   echo '<a href="view.php?   search=$search&start=$i&limit=$limit&price=$price&category=$category">$i</a>';
}
else
{
   echo '<span class="current">$i</span>';
}        
$l=$l+1;
  }
 echo "</p>";
  }
4

4 回答 4

3
<?php for($i=0;$i < $count1;$i=$i+$limit): ?>

  <?php if($i <> $start): ?>

 <a href="view.php?search=<?php echo $search;?>&start=<?php echo $i;?>&limit=<?php echo $limit;?>&price=<?php echo $price;?>&category=<?php echo $category;?>">
 <?php echo $i; ?></a>

  <?php else: ?>

  <span class="current"><?php echo $i;?></span>

  <?php endif; ?>
<?php endfor; ?>

CSS:

a,span.current{font-weight:bold;font-family:Verdana;}

所有都是内联元素,所以它们会保持...内联。在您的 CSS 中添加填充、文本装饰、颜色和任何内容。如果您的意图更清楚(中心?),我可以帮助您实现您想要的。远离旧的 html 和表格 :)

于 2012-10-05T20:48:39.603 回答
1

这是执行上述操作的另一种方法,并添加了一些附加功能:

$count1 = 10;    
$menu = '';

$link = array(
  'search' => ( isset($search) ? $search : $search = '' ),
  'start' => ( isset($start) ? $start : $start = 0 ),
  'limit' => ( isset($limit) ? $limit : $limit = 1 ),
  'price' => ( isset($price) ? $price : $price = '' ),
  'category' => ( isset($category) ? $category : $category = '' ),
);

foreach( range(0, $count1, $limit) as $i ) {
  $menu .= ( ($link['start'] = $i) == $start ? 
    '<span class="current">'.$i.'</span>' :
    '<a href="view.php?'.http_build_query($link).'">'.$i.'</a>'
  ) . PHP_EOL;
}

echo $menu;

(以上需要php5+)

关于 neeko 的评论,要将$start变量与链接中显示的文本分开 - 您所要做的就是引入另一个变量,该变量在每个循环中计数 - 或者,因为我们已经有了范围数组的键,我们可以使用它:

foreach( range(0, $count1, $limit) as $key => $i ) {
  $menu .= ( ($link['start'] = $i) == $start ? 
    '<span class="current">Page'.($key+1).'</span>' :
    '<a href="view.php?'.http_build_query($link).'">Page'.($key+1).'</a>'
  ) . PHP_EOL;
}

我用过$key + 1, 因为$key它将是从零开始的(即从零开始计数),但是 +1 只是改变了一些东西,所以我们从 1 开始计数。

于 2012-10-05T21:33:38.977 回答
0

我认为这是因为 center 是一个块元素,这意味着它不会与其他数字内联(但这不是我的专长,所以我可能错了。你可以把它们放在一张桌子上。

echo "<table><tr>";

for($i=0;$i < $count1;$i=$i+$limit)
{
    echo "<td>";
    if($i <> $start)
    {       
        echo "<a href='view.php?search=$search&start=$i&limit=$limit&price=$price&category=$category'><font face='Verdana' size='2'><b>&nbsp;$l&nbsp;</b></font></a> ";
    }
    else
    {
        echo "<center><font face='Verdana' size='4' color=#2E9AFE ><b>&nbsp;$l&nbsp;</b></font></center>";
    }
    echo "</td>";
}
echo "</tr></table>";
于 2012-10-05T20:43:07.023 回答
0

试试这个:

for($i=0;$i < $count1;$i=$i+$limit)
{
if($i <> $start)
{       
    echo "<a href='view.php?search=$search&start=$i&limit=$limit&price=$price&category=$category'><div style='font-family: verdana; font-size: 12px; font-weight: bold; float: left; position: relative; padding: 5px; margin-right: 5px;'>$l</div></a>";
}
else
{
    echo "<div style='font-family: verdana; font-size: 14px; font-weight: bold; float: left; position: relative; color: #2E9AFE; padding: 5px; margin-right: 5px;'>$l</div>";
}   

我已经更改了代码的 html 部分以显示在带有 float: left 和其他一些 css 调整的 div 元素中,所以现在它应该放在一行中......

于 2012-10-05T20:44:39.053 回答