Maison  >  Article  >  interface Web  >  自动化分页,HTML代码控制 思想_html/css_WEB-ITnose

自动化分页,HTML代码控制 思想_html/css_WEB-ITnose

WBOY
WBOYoriginal
2016-06-24 11:34:251245parcourir

1、绑定分页数据

  Request:主要是获取当前查询中所参与的所有条件

  pageSize:分页显示数量

  totalCount:分页总数

  currentPageStr:自定义参数(后面会更新该参数的用法和途径)

  tab:自定义参数(后面会更新该参数的用法和途径,和上面currentPageStr配合使用,需优化)

  pageIndexNumber:页面上显示当前页前、后多少页数数的数字

      如:显示当前页前后个5页的数字

  IsShouCount:是否显示总数量

2、用法,Response.Write页面输出一段html

<div class="m-t-20 paging">            <pre class="brush:php;toolbar:false">            <%Response.Write(ZCJExtensions.Pager(Request, 40, iCount, "pi",IsShouCount:true));%>            

 

 

3、源代码 方法主要用到请求头类的使用,HttpRequest 

public static class ZCJExtensions{    /// <summary>    /// 分页Pager显示(分页请求字符串默认为pi)    /// </summary>    /// <param name="pageSize">每页记录的数量</param>    /// <param name="totalCount">总记录数</param>    /// <param name="pageIndexNumber">显示页索引的数量</param>    /// <returns></returns>    public static string Pager(int pageSize, int totalCount,int pageIndexNumber = 10)    {        return ZCJExtensions.Pager(HttpContext.Current.Request, pageSize, totalCount, "pi", "", pageIndexNumber);    }    /// <summary>    /// 分页Pager显示        /// </summary>    /// <param name="requ">请求</param>    /// <param name="pageSize">每页记录的数量</param>    /// <param name="totalCount">总记录数</param>    /// <param name="currentPageStr">请求字符串</param>    /// <param name="tab">切换ID</param>    /// <param name="pageIndexNumber">显示页索引的数量</param>    /// <returns></returns>    public static string Pager(HttpRequest requ, int pageSize, int totalCount, string currentPageStr = "1",string tab="",int pageIndexNumber = 10,bool IsShouCount=false)    {        //var queryString = html.ViewContext.HttpContext.Request.QueryString;        string html = "";        var queryString = requ.QueryString;        int currentPage = 1; //当前页            var totalPages = Math.Max((totalCount + pageSize - 1) / pageSize, 1); //总页数            //var dict = new System.Web.Routing.RouteValueDictionary(html.ViewContext.RouteData.Values);        var dict = new System.Web.Routing.RouteValueDictionary(requ.Form);        var output = new System.Text.StringBuilder();        var url = requ.Url.AbsolutePath + "?" + currentPageStr + "=(*)";        if (tab.Length > 0)        {            url += "&tab=" + tab;        }        //与相应的QueryString绑定           foreach (string key in queryString.Keys)        {            if (!string.IsNullOrEmpty(key) && queryString[key] != null )            {                dict[key] = queryString[key];                if (key != currentPageStr && key.ToLower()!="tab")                {                    url += "&" + key + "=" + queryString[key];                }            }        }        //获取 ~/Page/{page number} 的页号参数          int.TryParse((dict[currentPageStr] != null) ? dict[currentPageStr].ToString() : "0", out currentPage);        if (currentPage <= 0) currentPage = 1;        if (totalPages > 1)        {            if (currentPage != 1)            {                dict[currentPageStr] = 1;                //output.AppendFormat("{0} ", html.RouteLink("<<", dict));                var pageunm = "1";                var tempurl = url.Replace("(*)", pageunm);                output.AppendFormat("{0}", "<a href='" + tempurl + "'>首页</a>");            }            if (currentPage > 1)            {                //处理上一页的连接                    dict[currentPageStr] = currentPage - 1;                var pageunm = (currentPage - 1).ToString();                var tempurl = url.Replace("(*)", pageunm);                //output.Append(html.RouteLink("<", dict));                output.Append("<a href='" + tempurl + "'>上一页</a>");            }            else            {                //output.Append("<span><</span>");            }            output.Append("");            int currint = pageIndexNumber / 2;            for (int i = 0; i <= pageIndexNumber; i++)            {                //一共最多显示10个页码,前面5个,后面5个                    if ((currentPage + i - currint) >= 1 && (currentPage + i - currint) <= totalPages)                    if (currint == i)                    {                        //当前页处理                            output.Append(string.Format("<span>{0}</span>", currentPage));                    }                    else                    {                        //一般页处理                           dict[currentPageStr] = currentPage + i - currint;                        var pageunm = (currentPage + i - currint).ToString();                        var tempurl = url.Replace("(*)", pageunm);                        //output.Append(html.RouteLink((currentPage + i - currint).ToString(), dict));                        output.Append("<a href='" + tempurl + "'>" + pageunm + "</a>");                    }                output.Append("");            }            if (currentPage < totalPages)            {                //处理下一页的链接                   dict[currentPageStr] = currentPage + 1;                var pageunm = (currentPage + 1).ToString();                //output.Append(html.RouteLink(">", dict));                var tempurl = url.Replace("(*)", pageunm);                output.Append("<a href='" + tempurl + "'>下一页</a>");            }            else            {                //output.Append(">");            }            output.Append("");            if (currentPage != totalPages)            {                dict[currentPageStr] = totalPages;                var pageunm = totalPages.ToString();                var tempurl = url.Replace("(*)", pageunm);                //output.Append(html.RouteLink(">>", dict));                output.Append("<a href='" + tempurl + "'>尾页</a>");            }            output.Append(" ");        }        output.AppendFormat("第{0}页/共{1}页", currentPage, totalPages);//这个统计加不加都行           if (IsShouCount == true)         {            output.AppendFormat(",共{0}条记录", totalCount);        }        //HtmlString        return output.ToString();    }}

 

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn