zoukankan      html  css  js  c++  java
  • ASP.NET中DataList数字分页代码 转

    代码转自http://hi.baidu.com/honfei css样式取自吴旗娃aspnetpager

    http://www.cnblogs.com/ndxsdhy/archive/2010/11/13/1876746.html

    效果:

    共1页       首页 上一页  1 2 3 4 5 6 7 8 9 10 ....下一页 末页

    调用页面(Aspx):

    在要显示分页导航的地方加个DIV标签:<div id="PageInfo" runat="server"></div>

    调用页的代码(CS):

    DataSet ds = db.getDs(sql);
    this.PageInfo.InnerHtml = PageNums.GetPageNum(ds,DataList1,12); //传入DataSet,DataList名称和分页大小

    PageNums实现分页类(PageNums.cs):下面附

    为了能配合上吴旗娃的分页样式, 做了细微的改动, 在此贴上全部的代码, 方便大家使用

    Default2.aspx.cs

    using System.Collections;
    using System.Configuration;
    using System.Data;
    using System.Linq;
    using System.Web;
    using System.Web.Security;
    using System.Web.UI;
    using System.Web.UI.HtmlControls;
    using System.Web.UI.WebControls;
    using System.Web.UI.WebControls.WebParts;
    using System.Xml.Linq;
    using System.Data;
    using System.Data.SqlClient;
    
    public partial class Default2 : System.Web.UI.Page
    {
        protected SqlConnection conn; //添加数据库的操作对象
        protected SqlDataAdapter da;
        protected DataSet ds;
        protected SqlCommand comm;
        protected void Page_Load(object sender, EventArgs e)
        {
            conn = new SqlConnection("Data Source=localhost;Initial Catalog=nd_data;User ID=sa;Password=aaaaaa");//取连接字符串,建立连接
            da = new SqlDataAdapter();
            da.SelectCommand = new SqlCommand("select  name,id from xs Order by id,name DESC ", conn);
            ds = new DataSet();
            try
            {
                conn.Open();
                da.Fill(ds, "abs");
                conn.Close();
            }
            catch (SqlException e1)
            {
                Response.Write(e1.ToString());
            }
    
    
            this.PageInfo.InnerHtml = PageNums.GetPageNum(ds, DataList1,5); //传入DataSet,DataList名称和分页大小
        }
    }

    Default2.aspx

    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default2.aspx.cs" Inherits="Default2" %>
    
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head runat="server">
        <title>无标题页</title>
        <style type="text/css">
            .paginator { font: 11px Arial, Helvetica, sans-serif;padding:10px 20px 10px 0; margin: 0px;}
            .paginator a {padding: 1px 6px; border: solid 1px #ddd; background: #fff; text-decoration: none;margin-right:2px}
            .paginator a:visited {padding: 1px 6px; border: solid 1px #ddd; background: #fff; text-decoration: none;}
            .paginator .cpb {padding: 1px 6px;font-weight: bold; font-size: 13px;border:none}
            .paginator a:hover {color: #fff; background: #ffa501;border-color:#ffa501;text-decoration: none;}
            
            .anpager { font: 11px Arial, Helvetica, sans-serif;margin:5px 4px 0 0;padding:4px 5px 0;}
            .anpager .cpb {background:#1F3A87;border:1px solid #CCCCCC;color:#FFFFFF;font-weight:bold;margin:0;padding:4px 5px 1px;}
            .anpager a {background:#FFFFFF;border:1px solid #CCCCCC;color:#1F3A87;margin: 0;padding:4px 5px 1px;text-decoration:none}
            .anpager a:hover{background:#1F3A87;border:1px solid #1F3A87;color:#FFFFFF;}
            
            .pages {  color: #999; }
            .pages a, .pages .cpb { text-decoration:none;float: left; padding: 0 5px; border: 1px solid #ddd;background: #ffff;margin:0 2px; font-size:11px; color:#000;}
            .pages a:hover { background-color: #E61636; color:#fff;border:1px solid #E61636; text-decoration:none;}
            .pages .cpb { font-weight: bold; color: #fff; background: #E61636; border:1px solid #E61636;}
        </style>
    </head>
    <body>
        <form id="form1" runat="server">
    <asp:DataList ID="DataList1" runat="server">
    <ItemTemplate>
    <asp:Label ID="lbNwes" runat="server" Text='<%#Eval("id")%>'></asp:Label >
         
    <asp:Label ID="lbTime" runat="server" Text='<%#Eval("name")%>'></asp:Label>
    </ItemTemplate>
    </asp:DataList>
        <br />
        <div id="PageInfo" runat="server" class="anpager"></div>
        </form>
    </body>
    </html>

    PageNums.cs

    using System;
    using System.Data;
    using System.Configuration;
    using System.Linq;
    using System.Web;
    using System.Web.Security;
    using System.Web.UI;
    using System.Web.UI.HtmlControls;
    using System.Web.UI.WebControls;
    using System.Web.UI.WebControls.WebParts;
    using System.Xml.Linq;
    
    /// <summary>
    ///PageNums 的摘要说明
    /// </summary>
    public class PageNums
    {
        /// </summary>
        /// <param name="ds">DataSet实例</param>
        /// <param name="datalistname">DataList名称</param>
        /// <param name="pagesize">分页大小</param>
        public static string GetPageNum(DataSet ds, DataList datalistname, int pagesize)
        {
            PagedDataSource objPds = new PagedDataSource();
            objPds.DataSource = ds.Tables[0].DefaultView;
            objPds.AllowPaging = true;
            int total = ds.Tables[0].Rows.Count;
            objPds.PageSize = pagesize;
            int page;
            if (HttpContext.Current.Request.QueryString["page"] != null)
                page = Convert.ToInt32(HttpContext.Current.Request.QueryString["page"]);
            else
                page = 1;
            objPds.CurrentPageIndex = page - 1;
            datalistname.DataSource = objPds;
            datalistname.DataBind();
            int allpage = 0;
            int next = 0;
            int pre = 0;
            int startcount = 0;
            int endcount = 0;
            string pagestr = "";
            if (page < 1) { page = 1; }
            //计算总页数
            if (pagesize != 0)
            {
                allpage = (total / pagesize);
                allpage = ((total % pagesize) != 0 ? allpage + 1 : allpage);
                allpage = (allpage == 0 ? 1 : allpage);
            }
            next = page + 1;
            pre = page - 1;
            startcount = (page + 5) > allpage ? allpage - 9 : page - 4;//中间页起始序号
            //中间页终止序号
            endcount = page < 5 ? 10 : page + 5;
            if (startcount < 1) { startcount = 1; } //为了避免输出的时候产生负数,设置如果小于1就从序号1开始
            if (allpage < endcount) { endcount = allpage; } //页码+5的可能性就会产生最终输出序号大于总页码,那么就要将其控制在页码数之内
            pagestr = "<a >"+"" + allpage + "页</a>    ";
            pagestr += page > 1 ? "<a href="" + HttpContext.Current.Request.CurrentExecutionFilePath + "?page=1">首页</a>  <a href="" + HttpContext.Current.Request.CurrentExecutionFilePath + "?page=" + pre + "">上一页</a>" : "<a>首页</a>" + "  " + "<a>上一页</a>";
           //中间页处理,这个增加时间复杂度,减小空间复杂度
            for (int i = startcount; i <= endcount; i++)
            {
                pagestr += page == i ? "  " +"<a class="cpb">"+ i + "</a>" : "  <a href="" + HttpContext.Current.Request.CurrentExecutionFilePath + "?page=" + i + "">" + i + "</a>";
            }
            pagestr += page != allpage ? "  <a href="" + HttpContext.Current.Request.CurrentExecutionFilePath + "?page=" + next + "">下一页</a>  <a href="" + HttpContext.Current.Request.CurrentExecutionFilePath + "?page=" + allpage + "">末页</a>" : "  " + "<a >下一页</a>" + "  " + "<a >末页</a>";
            return pagestr;
        }
    }

     

    下面是效果图:


       

        

        

    没有引用css类的时候是这样:

        

  • 相关阅读:
    整数拆分问题的四种解法
    通配符匹配算法
    grundland去色
    rgb和lab的转换
    .Net library that makes converting between color spaces and comparing colors easy
    彩色图像灰度化论文
    ps图片黑白调整算法
    分数化小数算法
    计算机安全专有名词
    入侵检测
  • 原文地址:https://www.cnblogs.com/eason-chan/p/3657369.html
Copyright © 2011-2022 走看看