请教:关于分页的问题!
大家好,我是新手,我做了一个PHP分页,基本效果已经实现了,我想让当前页的颜色与其它页颜色不同,应该怎么实现?我想了好几天实在搞不定啊!还有假如以后我的页数多了,如何隐藏页数? 并且怎样让当前页居中显示???请知道的高手,帮忙指点下!
inclued("conn.php"); //连接数据库
//分页
$pagesize=10; //设置一页显示条数
$qw=mysql_query("select count(*) from `blog`");
$we=mysql_fetch_array($qw);
$er=$we[0]; //得出数据库表总数
$pages=intval($er/$pagesize); //得出页数
if($er%$pagesize){
$pages++;
}
//设置当前页
if(isset($_GET['page'])){
$page=intval($_GET['page']);
}else{
$page=1;
}
$offset=$pagesize*($page - 1); //计算起始条数
$sql="select * from `blog` order by id desc limit $offset,$pagesize";
$query=mysql_query($sql);
while($rs=mysql_fetch_array($query)){
?>
...
/** * 设置分页样式 * * @access public * @param integer $showNumCount 显示几个数字(例如:1 2 3 ...) * @param integer $totalPage 数据的总页数 * @param integer $page 当前页数 * * @return array $pageNumList 页数(数字)列表 */function showNumber($showNumCount, $totalPage, $page){ $showNumCount = $totalPage >= $showNumCount ? $showNumCount : $totalPage; if($totalPage > $showNumCount && $page > ceil($showNumCount / 2)) { if($totalPage - $page > floor($showNumCount / 2)) { $pageNumList = array_slice(range(1, $totalPage), $page - floor($showNumCount / 2) - 1, $showNumCount); } else { $pageNumList = range($totalPage - $showNumCount + 1, $totalPage - $showNumCount + $showNumCount); } } else { $showNumCount = $showNumCount ? $showNumCount : 1; $pageNumList = range(1, $showNumCount); } return $pageNumList;}$showNumCount = 10; // 显示十个页码$totalPage = 100; // 假如一共有100页数据$currentPage = 9; // 假如当前选择的是第9页$pageNumList = showNumber($showNumCount, $totalPage, $currentPage);/*接下来你只需要在html中循环输出这些页码,加上连接即可,当然了,如果标识当前页的话,你可以类似这样{foreach from=$pageNumList item=page} <a href="...?page=%7B%24page%7D" style="font-color: red">{$page}</a>{/foreach}*/<div class="clear"> </div>