php实现的漂亮分页方法
程序员文章站
2022-06-30 10:58:50
分页页码显示算法
复制代码 代码如下:/** * 获取分页的html内容 * @param integer $page 当前页 * @...
分页页码显示算法
复制代码 代码如下:
/**
* 获取分页的html内容
* @param integer $page 当前页
* @param integer $pages 总页数
* @param string $url 跳转url地址 最后的页数以 '&page=x' 追加在url后面
*
* @return string html内容;
*/
public static function getpagehtml($page, $pages, $url){
//最多显示多少个页码
$_pagenum = 5;
//当前页面小于1 则为1
$page = $page<1?1:$page;
//当前页大于总页数 则为总页数
$page = $page > $pages ? $pages : $page;
//页数小当前页 则为当前页
$pages = $pages < $page ? $page : $pages;
//计算开始页
$_start = $page - floor($_pagenum/2);
$_start = $_start<1 ? 1 : $_start;
//计算结束页
$_end = $page + floor($_pagenum/2);
$_end = $_end>$pages? $pages : $_end;
//当前显示的页码个数不够最大页码数,在进行左右调整
$_curpagenum = $_end-$_start+1;
//左调整
if($_curpagenum<$_pagenum && $_start>1){
$_start = $_start - ($_pagenum-$_curpagenum);
$_start = $_start<1 ? 1 : $_start;
$_curpagenum = $_end-$_start+1;
}
//右边调整
if($_curpagenum<$_pagenum && $_end<$pages){
$_end = $_end + ($_pagenum-$_curpagenum);
$_end = $_end>$pages? $pages : $_end;
}
$_pagehtml = '<ul class="pagination">';
/*if($_start == 1){
$_pagehtml .= '<li><a title="第一页">«</a></li>';
}else{
$_pagehtml .= '<li><a title="第一页" href="'.$url.'&page=1">«</a></li>';
}*/
if($page>1){
$_pagehtml .= '<li><a title="上一页" href="'.$url.'&page='.($page-1).'">«</a></li>';
}
for ($i = $_start; $i <= $_end; $i++) {
if($i == $page){
$_pagehtml .= '<li class="active"><a>'.$i.'</a></li>';
}else{
$_pagehtml .= '<li><a href="'.$url.'&page='.$i.'">'.$i.'</a></li>';
}
}
/*if($_end == $pages){
$_pagehtml .= '<li><a title="最后一页">»</a></li>';
}else{
$_pagehtml .= '<li><a title="最后一页" href="'.$url.'&page='.$pages.'">»</a></li>';
}*/
if($page<$_end){
$_pagehtml .= '<li><a title="下一页" href="'.$url.'&page='.($page+1).'">»</a></li>';
}
$_pagehtml .= '</ul>';
echo $_pagehtml;
}
上一篇: vue.js中toast用法及使用toast弹框的实例代码
下一篇: 做西红柿汤的小技巧,你知道么