突出显示当前页码PHP分页

时间:2016-01-28 05:14:20

标签: php mysql pagination

我在解决这个问题时遇到了问题,所以我要求更专业的解决方案。我为我的产品列表设置了分页设置。问题是当我切换页面时,数字上的活动类没有显示或显示错误。例如,当用户单击2(第2页)时,它会显示第2页的项目,但是5是突出显示的项目。需要帮助解决此问题,以突出显示当前正在查看的页面。

此代码用于设置偏移量。

$totalrows = db_getvalue("select count(buyinfo_id) from buyinfo,user $addtable where buyinfo.user_id=user.user_id $clause $orderbyclause", $global_connection);
        if ($totalrows == "")
            $totalrows = 0;
        $totalpages = ceil($totalrows/$listcount);
        if ($totalpages > 1) {
            $curpageoffset = 0;
            if (isset($_REQUEST['offset'])) {
                if ($_REQUEST['offset'] >= $totalpages)
                    $curpageoffset = $totalpages - 1;
                else if ($_REQUEST['offset']>0)
                    $curpageoffset = $_REQUEST['offset']*$listcount-1;
            }
            $limitstr = " limit $curpageoffset,$listcount";
        }

例如,当我转到第3页时,它会显示www.site.com/?offset=2

我猜它是因为$ curpageoffset = $ _REQUEST [' offset'] * $ listcount-1;

这是负责页码的代码:

<?php
    if ($totalpages>1) {
            echo "<tr><td><ul class='pagination'>";
            echo "<li><a href='' aria-label='Previous' ";
            if ($curpageoffset == 0) {
                echo "onclick='return false;'";
            } else {
                echo "onclick='util_reload(\"posts/?offset=".($curpageoffset-1)."$pageparam\"); return false;'";
            }
            echo " ><span aria-hidden='true'>&laquo;</span></a></li>";

            $tmpctr = 0;
            while ($tmpctr < $totalpages) {
                $curstyle = "";
                if ($tmpctr == $curpageoffset)
                    $curstyle = "class='active'";

                echo "<li $curstyle><a href='' onclick='util_reload(\"posts/?offset=$tmpctr$pageparam\"); return false;'>";
                $tmpctr++;
                echo "$tmpctr</a></li>";
            }

            echo "<li><a href='' aria-label='Next' ";
            if ($curpageoffset >= $totalpages-1) {
                echo "onclick='return false;'";
            } else {
                echo "onclick='util_reload(\"posts/?offset=".($curpageoffset+1)."$pageparam\"); return false;'";
            }
            echo " ><span aria-hidden='true'>&raquo;</span></a></li>";

            echo "</ul></td></tr>";
    }
?>

1 个答案:

答案 0 :(得分:1)

由于您已设置curpageoffset的值以供在查询中使用,因此您无法在分页代码中使用它来突出显示您所在的页面...我会以这种方式更改您的代码..使用原始$ _REQUEST ['offset'],因为那基本上是页码。

while ($tmpctr < $totalpages) {
                $curstyle = "";
                if ($tmpctr == $_REQUEST['offset'])
                    $curstyle = "class='active'";

                echo "<li $curstyle><a href='' onclick='util_reload(\"posts/?offset=$tmpctr$pageparam\"); return false;'>";
                $tmpctr++;
                echo "$tmpctr</a></li>";
            }