读书人

jQuery+Ajax+PHP+Mysql实现分页展示数

发布时间: 2013-09-11 16:26:28 作者: rapoo

jQuery+Ajax+PHP+Mysql实现分页显示数据

jQuery+Ajax+PHP+Mysql实现分页显示数据

就2个文件,一个显示分页的文件和一个获取分页的文件

本例数据库与之前《jquery 翻页分页》是相同的

jQuery+Ajax+PHP+Mysql实现分页展示数据演示主要代码:

index.html

XML/HTML Code
  1. <script type="text/javascript">
  2. var curPage = 1; //当前页码
  3. var total,pageSize,totalPage;
  4. //获取数据
  5. function getData(page){
  6. $.ajax({
  7. type: 'POST',
  8. url: 'pages.php',
  9. data: {'pageNum':page-1},
  10. dataType:'json',
  11. beforeSend:function(){
  12. $("#list ul").append("<li id='loading'>loading...</li>");
  13. },
  14. success:function(json){
  15. $("#list ul").empty();
  16. total = json.total; //总记录数
  17. pageSize = json.pageSize; //每页显示条数
  18. curPage = page; //当前页
  19. totalPage = json.totalPage; //总页数
  20. var li = "";
  21. var list = json.list;
  22. $.each(list,function(index,array){ //遍历json数据列
  23. li += "<li><a href='#'>"+array['title']+"</a></li>";
  24. });
  25. $("#list ul").append(li);
  26. },
  27. complete:function(){ //生成分页条
  28. getPageBar();
  29. },
  30. error:function(){
  31. alert("数据加载失败");
  32. }
  33. });
  34. }
  35. //获取分页条
  36. function getPageBar(){
  37. //页码大于最大页数
  38. if(curPage>totalPage) curPage=totalPage;
  39. //页码小于1
  40. if(curPage<1) curPage=1;
  41. pageStr = "<span>共"+total+"条</span><span>"+curPage+"/"+totalPage+"</span>";
  42. //如果是第一页
  43. if(curPage==1){
  44. pageStr += "<span>首页</span><span>上一页</span>";
  45. }else{
  46. pageStr += "<span><a href='javascript:void(0)' rel='1'>首页</a></span><span><a href='javascript:void(0)' rel='"+(curPage-1)+"'>上一页</a></span>";
  47. }
  48. //如果是最后页
  49. if(curPage>=totalPage){
  50. pageStr += "<span>下一页</span><span>尾页</span>";
  51. }else{
  52. pageStr += "<span><a href='javascript:void(0)' rel='"+(parseInt(curPage)+1)+"'>下一页</a></span><span><a href='javascript:void(0)' rel='"+totalPage+"'>尾页</a></span>";
  53. }
  54. $("#pagecount").html(pageStr);
  55. }
  56. $(function(){
  57. getData(1);
  58. $("#pagecount span a").live('click',function(){
  59. var rel = $(this).attr("rel");
  60. if(rel){
  61. getData(rel);
  62. }
  63. });
  64. });
  65. </script>
  66. </head>
  67. <body>
  68. <h1 class="logo"><a href="http://www.freejs.net" title="freejs首页"><img src="../../images/logo.png" height="47" width="500" alt="freejs首页" /></a></h1>
  69. <div id="main_demo">
  70. <div align="center"><h2><a href="../../article_biaodan_10.html">jQuery+Ajax+PHP+Mysql实现分页显示数据</a></h2></div>
  71. <div id="main">
  72. <div id="list">
  73. <ul></ul>
  74. </div>
  75. <div id="pagecount"></div>
  76. </div>

pages.php

PHP Code
  1. <?php
  2. include_once('conn.php');
  3. $page = intval($_POST['pageNum']);
  4. $result = mysql_query("select * from content");
  5. $total = mysql_num_rows($result);//总记录数
  6. $pageSize = 6; //每页显示数
  7. $totalPage = ceil($total/$pageSize); //总页数
  8. $startPage = $page*$pageSize;
  9. $arr['total'] = $total;
  10. $arr['pageSize'] = $pageSize;
  11. $arr['totalPage'] = $totalPage;
  12. $query = mysql_query("select * from content order by id asc limit $startPage,$pageSize");
  13. while($row=mysql_fetch_array($query)){
  14. $arr['list'][] = array(
  15. 'id' => $row['id'],
  16. 'title' => $row['name'],
  17. );
  18. }
  19. //print_r($arr);
  20. echo json_encode($arr);
  21. ?>

原文地址:http://www.freejs.net/article_fenye_26.html

读书人网 >Ajax

热点推荐