本篇主要介紹PHP實現數位分頁功能,有興趣的朋友參考下,希望對大家有幫助。
學習重點:
1.LIMIT 用法
2.各種參數
3.超連結呼叫
第一:先在檔案中設定數字分頁模組;我的檔案是(blog.php)
程式碼如下:
//分页模块 $_page = $_GET['page']; $_pagesize = 10; $_pagenum = ($_page - 1) * $_pagesize; //首页要得到所有的数据总和 $_num=mysql_num_rows(_query("SELECT tg_id FROM tg_user")); $_pageabsolute=$_num / $_pagesize;
要注意的是在資料庫中取集的時候
程式碼如下:
//我们必须每次重新读取结果集,而不是从新去执行SQL语句。 $_result = _query("SELECT tg_username,tg_sex,tg_face FROM tg_user ORDER BY tg_reg_time DESC LIMIT $_pagenum,$_pagesize");
設定分頁循環的效果
<p id="page_num"> <ul> <?php for($i=0;$i<$_pageabsolute;$i++){ if ($_page == ($i+1)) { echo '<li><a href="blog.php?page='.($i+1).'" class="selected">'.($i+1).'</a></li>'; }else{ echo '<li><a href="blog.php?page='.($i+1).'">'.($i+1).'</li>'; } } ?> </ul> </p>
相對應的CSS
#page_num { height:20px; clear:both; padding:10px 0; position:relative; } #page_num ul { position:absolute; right:30px; height:20px; } #page_num ul li { float:left; width:26px; height:20px; } #page_num ul li a { display:block; width:20px; height:20px; line-height:20px; border:1px solid #333; text-align:center; text-decoration:none; } #page_num ul li a:hover,#page_num ul li a.selected { background:#666; font-weight:bold; color:#fff; }
在其中可能會因編碼出現容錯誤,解決的方法是
// 分页模块 if (isset ( $_GET ['page'] )) { // 在数据不再数据范围内出错的解决方法 $_page = $_GET['page']; // 是否为空,是否小于0,是否不是数字。//如果其中有一个是,那么就=1 if (empty ( $_page )||$_page < 0 || !is_numeric( $_page )) { $_page = 1; } else { $_page = intval ( $_page ); // 如果是数字,但是小数,那么就$_page = intval($_page);转换成整数 } } else { $_page = 1; } $_pagesize = 10; $_num = _num_rows( _query ( "SELECT tg_id FROM tg_user" ) ); if ($_num==0) { $_pageabsolute=1; }else{ $_pageabsolute=ceil($_num/$_pagesize); } //当页码大于总页码的时候,就会返回到总页码的最后一页 if ($_page>$_pageabsolute) { $_page=$_pageabsolute; } $_pagenum = ($_page - 1) * $_pagesize;
#總結:以上就是這篇文章的全部內容,希望能對大家的學習有所幫助。
相關推薦:
以上是PHP實作數位分頁功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!