用asp.net轻松打造功能完备的分页技术!!!!

用过asp开发过web程序的人都知道,分页让asp程序员是一件非常头痛的事,我在这就来说说用asp.net轻松打造的分页技术.

第一步我们在vs.net新建项目,这些我不说了,你自己搞定吧,我在这里主要贴出重要的代码.

1.webform1.aspx

1@ Page language="c#" Codebehind="WebForm1.aspx.cs" AutoEventWireup="false" Inherits="page.WebForm1" 
 1<html>
 2<head>
 3<title>WebForm1</title>
 4<meta content="Microsoft Visual Studio 7.0" name="GENERATOR"/>
 5<meta content="C#" name="CODE_LANGUAGE"/>
 6<meta content="JavaScript" name="vs_defaultClientScript"/>
 7<meta content=" http://schemas.microsoft.com/intellisense/ie5 " name="vs_targetSchema"/>
 8</head>
 9<body ms_positioning="GridLayout">
10<form id="Form1" method="post" runat="server">
11<table align="center">
12<tr>
13<td colspan="2" style="HEIGHT: 104px"><asp:datagrid allowpaging="True" backcolor="#FFE0C0" bordercolor="#FFC080" borderwidth="1px" cellpadding="3" font-names="Verdana" font-size="8pt" height="152px" horizontalalign="Center" id="DataGrid1" pagesize="5" runat="server" width="700px">
14<alternatingitemstyle backcolor="Linen">
15</alternatingitemstyle>
16<itemstyle verticalalign="Bottom">
17</itemstyle>
18<headerstyle backcolor="#FF8000" horizontalalign="Center" verticalalign="Bottom">
19</headerstyle>
20<footerstyle backcolor="White" horizontalalign="Justify">
21</footerstyle>
22<pagerstyle forecolor="Red" horizontalalign="Right" mode="NumericPages">
23</pagerstyle>
24</asp:datagrid></td>
25</tr>
26<tr align="middle">
27<td align="left"><font size="2">一共</font> <asp:label font-names="verdana" font-size="8pt" forecolor="#0000ff" id="lblallcount" runat="server"></asp:label> <font size="2">记录</font>
28<font size="2">共</font> <asp:label font-names="Verdana" font-size="8pt" forecolor="#0000ff" id="lblpagecount" runat="server"></asp:label> <font size="2">页</font>
29<font size="2">第</font> <asp:label font-names="Verdana" font-size="8pt" forecolor="#0000ff" id="lblcurrentindex" runat="server"></asp:label> <font size="2">页</font></td>
30<td align="right"><asp:linkbutton commandargument="first" font-names="Verdana" font-size="8pt" forecolor="#3300ff" id="first" runat="server"></asp:linkbutton>
31<asp:linkbutton commandargument="prev" font-names="Verdana" font-size="8pt" forecolor="#3300ff" id="prev" runat="server"></asp:linkbutton>
32<asp:linkbutton commandargument="next" font-names="Verdana" font-size="8pt" forecolor="#3300ff" id="next" runat="server"></asp:linkbutton>
33<asp:linkbutton commandargument="last" font-names="Verdana" font-size="8pt" forecolor="#3300ff" id="last" runat="server"></asp:linkbutton>
34<font size="2">跳转到第</font><asp:textbox columns="1" id="to" runat="server"></asp:textbox><font size="2">页</font><asp:button backcolor="WhiteSmoke" font-names="Verdana" id="go" runat="server" text="GO"></asp:button>
35</td>
36</tr>
37</table>
38</form>
39</body>
40</html>

2.webform1.cs

using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;

namespace page
{
///

1<summary>   
2/// WebForm1 的摘要说明。   
3/// </summary>

public class WebForm1 : System.Web.UI.Page
{
protected System.Web.UI.WebControls.Label lblpagecount;
protected System.Web.UI.WebControls.Label lblcurrentindex;
protected System.Web.UI.WebControls.LinkButton first;
protected System.Web.UI.WebControls.LinkButton prev;
protected System.Web.UI.WebControls.LinkButton next;
protected System.Web.UI.WebControls.DataGrid DataGrid1;
protected System.Web.UI.WebControls.TextBox to;
protected System.Web.UI.WebControls.Button go;
protected System.Web.UI.WebControls.Label lblallcount;
protected System.Web.UI.WebControls.LinkButton last;

void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
first.Text="最首页";
prev.Text="前一页";
next.Text="下一页";
last.Text="最后页";
if(!IsPostBack)
{
BindGrid();
}
}

#region Web Form Designer generated code
override protected void OnInit(EventArgs e)
{
//
// CODEGEN:该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}

///

1<summary>   
2/// 设计器支持所需的方法 - 不要使用代码编辑器修改   
3/// 此方法的内容。   
4/// </summary>

private void InitializeComponent()
{
this.DataGrid1.PageIndexChanged += new System.Web.UI.WebControls.DataGridPageChangedEventHandler(this.Page_Changed);
this.first.Click += new System.EventHandler(this.btnClick);
this.prev.Click += new System.EventHandler(this.btnClick);
this.next.Click += new System.EventHandler(this.btnClick);
this.last.Click += new System.EventHandler(this.btnClick);
this.go.Click += new System.EventHandler(this.goClick);
this.Load += new System.EventHandler(this.Page_Load);

}
#endregion

void Page_Changed(object source, System.Web.UI.WebControls.DataGridPageChangedEventArgs e)
{
DataGrid1.CurrentPageIndex=e.NewPageIndex;
BindGrid();
}
void BindGrid()
{
SqlConnection cn=new SqlConnection("server=localhost;database=pubs;uid=sa;pwd=");
cn.Open();
SqlDataAdapter da=new SqlDataAdapter("select * from authors",cn);
DataSet ds=new DataSet();
da.Fill(ds,"authors");
DataGrid1.DataSource=ds.Tables["authors"].DefaultView;
DataGrid1.DataBind();
cn.Close();
showstate();
}
void showstate()
{
SqlConnection cn=new SqlConnection("server=localhost;database=pubs;uid=sa;pwd=");
cn.Open();
SqlDataAdapter da=new SqlDataAdapter("select * from authors",cn);
DataSet ds=new DataSet();
da.Fill(ds,"authors");
DataTable dt=ds.Tables["authors"];
int count=dt.Rows.Count;
lblallcount.Text=count.ToString();
lblpagecount.Text=DataGrid1.PageCount.ToString();
lblcurrentindex.Text=(DataGrid1.CurrentPageIndex+1).ToString();
}
void btnClick(object sender,System.EventArgs e)
{
string arg=((LinkButton)sender).CommandArgument;
switch(arg)
{
case ("first"):
DataGrid1.CurrentPageIndex=0;
break;
case ("prev"):
if(DataGrid1.CurrentPageIndex>0)
DataGrid1.CurrentPageIndex--;
break;
case ("next"):
if(DataGrid1.CurrentPageIndex<(DataGrid1.PageCount-1))
DataGrid1.CurrentPageIndex++;
break;
case ("last"):
DataGrid1.CurrentPageIndex=DataGrid1.PageCount-1;
break;
default:
DataGrid1.CurrentPageIndex=Convert.ToInt32(arg);
break;
}
BindGrid();
}

private void goClick(object sender, System.EventArgs e)
{
if(to.Text.Trim()!="")
{
int index=Int32.Parse(to.Text.Trim())-1;
if(index>=0&&index<DataGrid1.PageCount)
{
DataGrid1.CurrentPageIndex=index;
}
}
BindGrid();
}

}
}

好了,现在这个分页的web 程序完成了,你去试试.

Published At
Categories with Web编程
Tagged with
comments powered by Disqus