C#前面
<asp:Button id="btnPrev" runat="server" Text="<<" OnClick="btnPrev_Click"></asp:Button>
<asp:Button id="btnNext" onclick="btnNext_Click" runat="server" Text=">>"></asp:Button>
<asp:Label id="lblIndex" runat="server"></asp:Label>
后面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 estore
{
/// <summary>
/// ProductList1 的摘要说明。
/// </summary>
public class ProductList1 : System.Web.UI.Page
{
protected System.Web.UI.WebControls.Button btnNext;
protected System.Web.UI.WebControls.Button btnPrev;
protected System.Web.UI.WebControls.DataList MyList;
protected System.Web.UI.WebControls.Label lblIndex;
public string Class_No;
public int index;
private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
if(!Page.IsPostBack)
{
this.lblIndex.Text="1";
BindDataToDataList();
}
}
private void BindDataToDataList()
{ Class_No=Request.Params["Class_No"];
index=System.Convert.ToInt32(this.lblIndex.Text);//当前页码
//初始化数据集
SqlConnection Con=new SqlConnection("Data Source=KINGS;Initial Catalog=estore; User ID=sa;Pwd=02620119;");
Con.Open();
SqlDataAdapter cmd=new SqlDataAdapter("ProductList1_Select",Con);
cmd.SelectCommand.Parameters.Add("@Class_No",Class_No);
cmd.SelectCommand.CommandType=CommandType.StoredProcedure;
DataSet ds=new DataSet();
cmd.Fill(ds,"Class");
PagedDataSource ps=new PagedDataSource();
ps.DataSource=ds.Tables["Class"].DefaultView;
//绑定数据
ps.AllowPaging=true;
ps.PageSize=4;
ps.CurrentPageIndex=index-1;//设置新的索引
//索引按钮的状态
this.btnNext.Enabled=true;
this.btnPrev.Enabled=true;
if(index==1)
{
this.btnPrev.Enabled=false;
}
else if(index==ps.Count)
{
this.btnNext.Enabled=false;
}
//绑定数据
this.MyList.DataSource=ps;
this.MyList.DataBind();
}
#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}
/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.btnNext.Click += new System.EventHandler(this.btnNext_Click);
this.btnPrev.Click += new System.EventHandler(this.btnPrev_Click);
this.Load += new System.EventHandler(this.Page_Load); }
#endregion public void btnNext_Click(object sender, System.EventArgs e)
{
this.lblIndex.Text=System.Convert.ToString(System.Convert.ToInt32(this.lblIndex.Text)+1);//上一页
//重新绑定数据
BindDataToDataList(); } public void btnPrev_Click(object sender, System.EventArgs e)
{
this.lblIndex.Text=System.Convert.ToString(System.Convert.ToInt32(this.lblIndex.Text)-1);//上一页
//重新绑定数据
BindDataToDataList();
}
}
}
进入按按钮没反应,不晓得为什么,不知道是按钮原因还是程序原因,但ps.CurrentPageIndex=index-1改成ps.CurrentPageIndex=1,页面是能显示第二页的东西.
<asp:Button id="btnPrev" runat="server" Text="<<" OnClick="btnPrev_Click"></asp:Button>
<asp:Button id="btnNext" onclick="btnNext_Click" runat="server" Text=">>"></asp:Button>
<asp:Label id="lblIndex" runat="server"></asp:Label>
后面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 estore
{
/// <summary>
/// ProductList1 的摘要说明。
/// </summary>
public class ProductList1 : System.Web.UI.Page
{
protected System.Web.UI.WebControls.Button btnNext;
protected System.Web.UI.WebControls.Button btnPrev;
protected System.Web.UI.WebControls.DataList MyList;
protected System.Web.UI.WebControls.Label lblIndex;
public string Class_No;
public int index;
private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
if(!Page.IsPostBack)
{
this.lblIndex.Text="1";
BindDataToDataList();
}
}
private void BindDataToDataList()
{ Class_No=Request.Params["Class_No"];
index=System.Convert.ToInt32(this.lblIndex.Text);//当前页码
//初始化数据集
SqlConnection Con=new SqlConnection("Data Source=KINGS;Initial Catalog=estore; User ID=sa;Pwd=02620119;");
Con.Open();
SqlDataAdapter cmd=new SqlDataAdapter("ProductList1_Select",Con);
cmd.SelectCommand.Parameters.Add("@Class_No",Class_No);
cmd.SelectCommand.CommandType=CommandType.StoredProcedure;
DataSet ds=new DataSet();
cmd.Fill(ds,"Class");
PagedDataSource ps=new PagedDataSource();
ps.DataSource=ds.Tables["Class"].DefaultView;
//绑定数据
ps.AllowPaging=true;
ps.PageSize=4;
ps.CurrentPageIndex=index-1;//设置新的索引
//索引按钮的状态
this.btnNext.Enabled=true;
this.btnPrev.Enabled=true;
if(index==1)
{
this.btnPrev.Enabled=false;
}
else if(index==ps.Count)
{
this.btnNext.Enabled=false;
}
//绑定数据
this.MyList.DataSource=ps;
this.MyList.DataBind();
}
#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}
/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.btnNext.Click += new System.EventHandler(this.btnNext_Click);
this.btnPrev.Click += new System.EventHandler(this.btnPrev_Click);
this.Load += new System.EventHandler(this.Page_Load); }
#endregion public void btnNext_Click(object sender, System.EventArgs e)
{
this.lblIndex.Text=System.Convert.ToString(System.Convert.ToInt32(this.lblIndex.Text)+1);//上一页
//重新绑定数据
BindDataToDataList(); } public void btnPrev_Click(object sender, System.EventArgs e)
{
this.lblIndex.Text=System.Convert.ToString(System.Convert.ToInt32(this.lblIndex.Text)-1);//上一页
//重新绑定数据
BindDataToDataList();
}
}
}
进入按按钮没反应,不晓得为什么,不知道是按钮原因还是程序原因,但ps.CurrentPageIndex=index-1改成ps.CurrentPageIndex=1,页面是能显示第二页的东西.
DataList的分页技术
作者:孟宪会 出自:【孟宪会之精彩世界】 发布日期:2003年4月28日 5点36分48秒
-------------------------------------------------
按按钮没反应,检查一下事件是丢失另外查看一个你的index的值是什么