zoukankan      html  css  js  c++  java
  • jquery+ajax分页

    先看效果图:

    实现原理很简单,使用了jquery.pagination这个插件,每当点击页码时异步去服务器去取该页的数据,简单介绍如下:

    一、数据库表结构:很简单  就四个字段 分别是News_id  News_title  News_time  News_readtimes

    二、前台页面代码:

        <head runat="server">  
            <title>JQuery无刷新分页</title>  
            <link href="Styles/common.css" rel="stylesheet" type="text/css" />  
            <link href="Styles/paging.css" rel="stylesheet" type="text/css" />  
            <script src="Scripts/jquery-1.4.1.js" type="text/javascript"></script>  
            <script src="Scripts/jquery.pagination.js" type="text/javascript"></script>  
            <script type="text/javascript">      
            var pageIndex = 0;  
            var pageSize = 3;  
             
            $(function() {         
                InitTable(0);                
                                         
                $("#Pagination").pagination(<%=pageCount %>, {  
                    callback: PageCallback,  
                    prev_text: '上一页',  
                    next_text: '下一页',  
                    items_per_page: pageSize,  
                    num_display_entries: 6,//连续分页主体部分分页条目数  
                    current_page: pageIndex,//当前页索引  
                    num_edge_entries: 2//两侧首尾分页条目数  
                });  
                      
                //翻页调用  
                function PageCallback(index, jq) {             
                    InitTable(index);  
                }  
          
                //请求数据  
                function InitTable(pageIndex) {                                  
                    $.ajax({   
                        type: "POST",  
                        dataType: "text",  
                        url: 'Ajax/PagerHandler.ashx',  
                        data: "pageIndex=" + (pageIndex + 1) + "&pageSize=" + pageSize,  
                        success: function(data) {                                   
                            $("#Result tr:gt(0)").remove();//移除Id为Result的表格里的行,从第二行开始(这里根据页面布局不同页变)  
                            $("#Result").append(data);//将返回的数据追加到表格  
                        }  
                    });              
                }  
            });  
            </script>  
        </head>  
        <form id="form1" runat="server">  
            <center>  
                <table id="Result" border="1" cellpadding="5" style="border-collapse: collapse; margin:20px;  
                    border: solid 1px #85A8BE;60%">  
                    <tr>  
                        <th style=" 10%">  
                            ID  
                        </th>  
                        <th style=" 60%">  
                            标题  
                        </th>  
                        <th style=" 20%">  
                            更新时间  
                        </th>  
                        <th style=" 10%">  
                            点击量  
                        </th>  
                    </tr>  
                </table>  
                <div id="Pagination" class="paging">  
                </div>  
            </center>  
            </form>  

    三、页面后台文件

    这里主要是获取记录总数:

    public string pageCount = string.Empty;//总条目数

            protected void Page_Load(object sender, EventArgs e)
            {
                if (!IsPostBack)
                {
                    pageCount = new News().GetNewsCount();
                }
            }

    四、最主要的是ajax处理程序:PagerHandler.ashx

        public class PagerHandler : IHttpHandler  
           {  
               public void ProcessRequest(HttpContext context)  
               {  
                   context.Response.ContentType = "text/plain";  
                   string str = string.Empty;  
                   int pageIndex = Convert.ToInt32(context.Request["pageIndex"]);  
                   int size = Convert.ToInt32(context.Request["pageSize"]);  
                   if (pageIndex == 0)  
                   {  
                       pageIndex = 1;  
                   }  
                   int count = 0;  
          
                   News n = new News();  
                   List<News> list = n.GetNewsList(pageIndex, size, ref count);  
                   StringBuilder sb = new StringBuilder();  
                   foreach (News p in list)  
                   {  
                       sb.Append("<tr><td>");  
                       sb.Append(p.News_id);  
                       sb.Append("</td><td>");  
                       sb.Append("<a href='#'>"+p.News_title+"</a>");  
                       sb.Append("</td><td>");  
                       sb.Append(p.News_time);  
                       sb.Append("</td><td>");  
                       sb.Append(p.News_readtimes);  
                       sb.Append("</td></tr>");  
                   }  
                   str = sb.ToString();  
                   context.Response.Write(str);  
               }  
          
               public bool IsReusable  
               {  
                   get  
                   {  
                       return false;  
                   }  
               }  
           }  
  • 相关阅读:
    3月工作问题总结
    【读书笔记】linux编程艺术
    项目管理工具 Trac入门
    [node.js]开放平台接口调用测试
    mysql 高并发更新计数问题
    memcache 问题 socket or its streams already null in trueClose call
    hadoop学习笔记
    node.js学习与应用
    mc参数备忘&javajson备忘
    WCF技术剖析_学习笔记之三
  • 原文地址:https://www.cnblogs.com/zhujiabin/p/4560960.html
Copyright © 2011-2022 走看看