zoukankan      html  css  js  c++  java
  • ASP.NET中刷新分页

    1,第一次全部把数据加载到内存中,然后再做分页,性能差,不推荐。

    2,GridView自带分页

    3,AspNetPager分页控件  这个是第三分控件需要下载,很好用

    4,自己写分页

    前三种就不介绍如何写了,网上很多,今天就来记录一下自己写的分页,不需要下载任何东西,全部都是代码完成。

    原理则是通过URL来传递参数(第几页,每个多少个,总记录数等),最终生成这样的,每个都是一个超链接,只是传的当前页的参数不同

    我们的前台

      <form id="form1" runat="server">
            <div>
    //数据显示 <asp:Repeater ID="rpTest" runat="server"> <HeaderTemplate> <table style="80%"> <tr> <th style="20%">产品名</th> <th style="20%">单价</th> <th style="20%">分类ID</th> <th style="20%">你猜猜</th> </tr> </HeaderTemplate> <ItemTemplate> <tr> <td><%#Eval("[ProductName]") %></td> <td><%#Eval("[UnitPrice]") %></td> <td><%#Eval("[CategoryID]") %></td> <td><%#Eval("[QuantityPerUnit]") %></td> </tr> </ItemTemplate> <FooterTemplate> </table> </FooterTemplate> </asp:Repeater> </div> <br />
    //分页 <div class="page"> <div class="details"> <span>每页<font><%=PageSize %></font>条</span> <span>共<font><%=PageCount %></font>条记录</span> </div> <div id="PageContent" class="paging" runat="server"> </div>

             <script>
                  function Jump() {     //跳转方法       
                     window.location.href = "FenYeDemoOne.aspx?PageIndex=" + $("#textPage").val();
                    }
             </script>

    结构我们准备好了,然后把我们的样式给进来

    /* 分页 --------------- */
    .page{ 100%; float:left; margin:-1px 0 0 0; background:#C9E4FF;}
    .details{ height:26px; float:left; padding:16px 0 16px 16px;}
    .details span{ height:26px; line-height:26px; float:left; padding:0 5px 0 0;}
    .details span font{ padding:0 5px;}
    .paging{ height:26px; float:right; padding:16px 16px 16px 0;}
    .paging a{ height:26px; float:left; line-height:26px; padding:0 9px; margin:0 0 0 6px; background:#FFF; border-radius:2px;}
    .paging span{ height:26px; float:left; line-height:26px; padding:0 10px; margin:0 0 0 6px;}
    .paging span.opt{ background:#009EFF; color:#FFF;}
    .paging a:hover{ text-decoration:none;}
    .paging input{ 58px; height:26px; float:left; margin:0 0 0 6px; text-align:center;/* border:1px solid #D2D7DD; border-right:0px;*/}
    .paging a.res{ height:26px; float:left; color:#FFF; line-height:26px; margin:0px; border:0px; background:#009EFF; border-radius:0 2px 2px 0;}
    .paging a.res:hover{background:#00B6EC;}
    .paging span.cpb{ background:#009EFF; color:#FFF;}
    .paging span.disabled, .paging span.disabled{ height:26px; float:left; line-height:26px; padding:0 9px; margin:0 0 0 6px; background:#FFF;}

    前台我们准备好了,我们来看后台,后台才是我们的主要

      public int PageSize = 5; //每页显示多少条数据
        public int PageIndex  //当前页
        {
            get
            {
                object obj = ViewState["PageIndex"];
                return obj == null ? 1 : Convert.ToInt32(obj);
            }
            set
            {
                ViewState["PageIndex"] = value;
            }
        }
    
        public int PageCount   //总记录数
        {
            get
            {
                object obj = ViewState["PageCount"];
                return obj == null ? 0 : Convert.ToInt32(obj);
            }
            set
            {
                ViewState["PageCount"] = value;
            }
        }
    
        public int TotalPage   //总页数
        {
            get
            {
                object obj = ViewState["TotalPage"];
                return obj == null ? 1 : Convert.ToInt32(obj);
            }
            set
            {
                ViewState["TotalPage"] = value;
            }
        }
       

    以上都基本会有

     protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                //点的是第几页
                PageIndex = Request.QueryString["PageIndex"] == null ? 1 : Convert.ToInt32(Request.QueryString["PageIndex"].ToString());
                BingData(); //绑定数据
            }
        }
    
        void BingData() {
    
            //string textPage = hfPage.Value;  跳转的值
            //总记录数  
            PageCount = Convert.ToInt32(SQLDB.SqlHelper.ExecuteScalar(conn, "select count(*) from Products"));
    
            //计算总页数
            if (PageCount % PageSize == 0)
            {
                TotalPage = PageCount / PageSize;
            }
            else
            {
                TotalPage = (PageCount / PageSize) + 1;
            }
            //这里可以的话做个判断,跳转的时候如果输入大于最大的值就取最大值,小于最小值就取最小值
            //if (!string.IsNullOrEmpty(textPage))
            //{
            //    PageIndex = Convert.ToInt32(textPage);
    
            //    if (Convert.ToInt32(textPage) > TotalPage)
            //    {
            //        PageIndex = TotalPage == 0 ? 1 : TotalPage;
            //    }
            //    if (Convert.ToInt32(textPage) <= 0)
            //    {
            //        PageIndex = 1;
            //    }
            //}
    
            //SQL语句
           string sql = "select top "+PageSize+"* from Products where ProductID not in (select  top " + PageSize * (PageIndex - 1) + " ProductID from Products)";
           rpTest.DataSource=SQLDB.SqlHelper.ExecuteDataSet(conn, sql); //数据源
           rpTest.DataBind();
           string pageUrl = Utils.CombUrlTxt("FenYeDemoOne.aspx", "PageIndex={0}",
                   "__PageIndex__");//传过去的url,例如:XX.aspx?X=A&Y=B&Z=C....
           PageContent.InnerHtml = Utils.OutPageList(this.PageSize, this.PageIndex, this.PageCount, pageUrl, 5); //分页方法,最后一个参数书店是中间显示多少个
        }

    后台主要是Utils里面的两个方法

    /// <summary>
            /// 组合URL参数
            /// </summary>
            /// <param name="_url">页面地址</param>
            /// <param name="_keys">参数名称</param>
            /// <param name="_values">参数值</param>
            /// <returns>String</returns>
            public static string CombUrlTxt(string _url, string _keys, params string[] _values)
            {
                StringBuilder urlParams = new StringBuilder();
                try
                {
                    string[] keyArr = _keys.Split(new char[] { '&' });
                    for (int i = 0; i < keyArr.Length; i++)
                    {
                        if (!string.IsNullOrEmpty(_values[i]) && _values[i] != "0")
                        {
                            _values[i] = UrlEncode(_values[i]);
                            urlParams.Append(string.Format(keyArr[i], _values) + "&");
                        }
                    }
                    if (!string.IsNullOrEmpty(urlParams.ToString()) && _url.IndexOf("?") == -1)
                        urlParams.Insert(0, "?");
                }
                catch
                {
                    return _url;
                }
                return _url + DelLastChar(urlParams.ToString(), "&");   //FenYeDemoOne.aspx?PageIndex=__PageIndex__
    }
      /// <summary>
            /// URL字符编码
            /// </summary>
            public static string UrlEncode(string str)
            {
                if (string.IsNullOrEmpty(str))
                {
                    return "";
                }
                str = str.Replace("'", "");
                return HttpContext.Current.Server.UrlEncode(str);
            }
      /// <summary>
            /// 删除最后结尾的指定字符后的字符
            /// </summary>
            public static string DelLastChar(string str, string strchar)
            {
                if (string.IsNullOrEmpty(str))
                    return "";
                if (str.LastIndexOf(strchar) >= 0 && str.LastIndexOf(strchar) == str.Length - 1)
                {
                    return str.Substring(0, str.LastIndexOf(strchar));
                }
                return str;
            }

    url里面的参数我们拼接好了

        /// <summary>
            /// 返回分页页码
            /// </summary>
            /// <param name="pageSize">页面大小</param>
            /// <param name="pageIndex">当前页</param>
            /// <param name="totalCount">总记录数</param>
            /// <param name="linkUrl">链接地址,__id__代表页码</param>
            /// <param name="centSize">中间页码数量</param>
            /// <returns></returns>
            public static string OutPageList(int pageSize, int pageIndex, int totalCount, string linkUrl, int centSize)
            {
                //计算页数
                if (totalCount < 1 || pageSize < 1)
                {
                    return "";
                }
                int pageCount = totalCount / pageSize;
                //if (pageCount < 1)
                //{
                //    return "";
                //}
                if (totalCount % pageSize > 0)
                {
                    pageCount += 1;
                }
                if (pageCount < 1)
                {
                    return "";
                }
                StringBuilder pageStr = new StringBuilder();
                string pageId = "__PageIndex__";
                string firstBtn = "<a href="" + ReplaceStr(linkUrl, pageId, (pageIndex - 1).ToString()) + "">«上一页</a>";
                string lastBtn = "<a href="" + ReplaceStr(linkUrl, pageId, (pageIndex + 1).ToString()) + "">下一页»</a>";
                string firstStr = "<a href="" + ReplaceStr(linkUrl, pageId, "1") + "">1</a>";
                string lastStr = "<a href="" + ReplaceStr(linkUrl, pageId, pageCount.ToString()) + "">" + pageCount.ToString() + "</a>";
    
                string textPage = "<input id="textPage"  value="" + pageIndex + "" type="text">";
                string JumpPage = "<a class="res" href="javascript:Jump();">跳转</a>";
    
                if (pageIndex <= 1)
                {
                    firstBtn = "<span class="disabled">«上一页</span>";
                }
                if (pageIndex >= pageCount)
                {
                    lastBtn = "<span class="disabled">下一页»</span>";
                }
                if (pageIndex == 1)
                {
                    firstStr = "<span class="cpb">1</span>";
                }
                if (pageIndex == pageCount && pageCount > 1)
                {
                    lastStr = "<span class="cpb">" + pageCount.ToString() + "</span>";
                }
                else if (pageCount == 1)
                {
                    lastStr = "";
                }
                int firstNum = pageIndex - (centSize / 2); //中间开始的页码
                if (pageIndex < centSize)
                    firstNum = 2;
                int lastNum = pageIndex + centSize - ((centSize / 2) + 1); //中间结束的页码
                if (lastNum >= pageCount)
                    lastNum = pageCount - 1;
                pageStr.Append(firstBtn + firstStr);
                if (pageIndex >= centSize)
                {
                    pageStr.Append("<span>...</span>
    ");
                }
                for (int i = firstNum; i <= lastNum; i++)
                {
                    if (i == pageIndex)
                    {
                        pageStr.Append("<span class="cpb">" + i + "</span>");
                    }
                    else
                    {
                        pageStr.Append("<a href="" + ReplaceStr(linkUrl, pageId, i.ToString()) + "">" + i + "</a>");
                    }
                }
                if (pageCount - pageIndex > centSize - ((centSize / 2)))
                {
                    pageStr.Append("<span>...</span>");
                }
                pageStr.Append(lastStr + lastBtn);
                pageStr.Append(textPage);
                pageStr.Append(JumpPage);
                return pageStr.ToString();
            }
       /// <summary>
            /// 替换指定的字符串
            /// </summary>
            /// <param name="originalStr">原字符串</param>
            /// <param name="oldStr">旧字符串</param>
            /// <param name="newStr">新字符串</param>
            /// <returns></returns>
            public static string ReplaceStr(string originalStr, string oldStr, string newStr)
            {
                if (string.IsNullOrEmpty(oldStr))
                {
                    return "";
                }
                return originalStr.Replace(oldStr, newStr);
            }

    显示效果

     

    ------------------------------------------------------------------------

    到此我们手动分页已完成,这样页面是会刷新的,下篇无刷新分页————》自定义ASP.NET中无刷新分页

  • 相关阅读:
    数组,集合,泛型
    DataSet和实体,泛型集合
    数据源绑定控件的Row/ItemDataBound事件
    Access 中时间格式 yyyyMMdd HH:mm:ss
    IMG标记的alt属性和title属性详解
    后台代码(cs)中加空格
    数据绑定控件之绑定项
    数据绑定控件之DataBound事件
    DataSet,DataTable,DateView的关系和用法
    程序编程网
  • 原文地址:https://www.cnblogs.com/Sea1ee/p/6691378.html
Copyright © 2011-2022 走看看