asp.net中datalist分页的问题??

本人是新手,刚接触asp.net,参考了网上的教程自己写一个datalist分页内容,下面是代码,不知道在oncommand事件后怎样补充了,有没有高手指点一下,麻烦了~... 本人是新手,刚接触asp.net,参考了网上的教程自己写一个datalist分页内容,下面是代码,不知道在oncommand事件后怎样补充了,有没有高手指点一下,麻烦了~~
HTML代码:
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Datalist.aspx.cs" Inherits="Datalist" %>

<!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>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:DataList ID="DataList1" runat="server" RepeatColumns="2">
<ItemTemplate>
<table>
<tr>
<td><%#Eval("id") %></td>
<td><%#Eval("classname") %></td>
</tr>
</table>
</ItemTemplate>
</asp:DataList>
<asp:LinkButton ID="LinkButton1" runat="server" Font-Size="12px" CommandName="shouye" OnCommand="page_onclick">首页</asp:LinkButton>
<asp:LinkButton ID="LinkButton2" runat="server" Font-Size="12px" CommandName="prev" OnCommand="page_onclick">上页</asp:LinkButton>
<asp:LinkButton ID="LinkButton3" runat="server" Font-Size="12px" CommandName="next" OnCommand="page_onclick">下页</asp:LinkButton>
<asp:LinkButton ID="LinkButton4" runat="server" Font-Size="12px" CommandName="weiye" OnCommand="page_onclick">尾页</asp:LinkButton></div>
</form>
</body>
</html>

C#代码:

using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;
public partial class Datalist : System.Web.UI.Page
{
string sql = "select classname,id from productsclass";
string sqlconstr = "server=(local);database=book;uid=sa;pwd=;";

protected void Page_Load(object sender, EventArgs e)
{
datalistbind();
}
public void datalistbind()
{
Ado ado=new Ado(sqlconstr);
SqlDataAdapter da = ado.get_SqlDataAdapter(sql);
DataSet ds = new DataSet();
da.Fill(ds, "a");
PagedDataSource ps = new PagedDataSource();
ps.DataSource = ds.Tables["a"].DefaultView;
ps.AllowPaging = true;
ps.PageSize = 6;
this.DataList1.DataSource = ps;
this.DataList1.DataBind();
if (ps.IsFirstPage)
{
LinkButton1.Enabled = false;
LinkButton2.Enabled = false;
}
if (ps.IsLastPage)
{
LinkButton3.Enabled = false;
LinkButton4.Enabled = false;
}
}
public void page_onclick(object sender, CommandEventArgs e)
{
datalistbind();

}
}
展开
 我来答
椎拐锰0
2009-10-22
知道答主
回答量:2
采纳率:0%
帮助的人:0
展开全部
很好
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

public partial class _Default : System.Web.UI.Page
{
DBHelper db = new DBHelper();
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
pagesize();
//DBHelper db = new DBHelper();
//GridView1.DataSource = db.GetAllBook();
//GridView1.DataBind();
}

}
protected void Button1_Click(object sender, EventArgs e)
{
DBHelper db = new DBHelper();
GridView1.DataSource = db.GetBook(int.Parse(TextBox1.Text));
GridView1.DataBind();
}
protected void GridView1_PageIndexChanging(object sender, GridViewPageEventArgs e)
{
DBHelper db = new DBHelper();
GridView1.PageIndex = e.NewPageIndex;//把新获得索引设置为当前页的索引
GridView1.DataSource = db.GetAllBook();
GridView1.DataBind();
}
public void pagesize()
{

PagedDataSource page = new PagedDataSource();//封装数据,绑定控件
page.DataSource = db.GetAllBook().Tables[0].DefaultView;//指定数据源,而datasource这个控件不能直接来绑定数据而只能绑定视图
page.AllowPaging = true;//是否启动分页
page.PageSize = 5;//行数
page.CurrentPageIndex = int.Parse(this.lbl_pagecurent.Text)-1;//设定或获取当前页的索引
lbl_count.Text =page.PageCount.ToString();//获取显示数据源中的所有项所需要的总页数
int pagecurent = int.Parse(this.lbl_pagecurent.Text);//定义一个变量来获取当前第几页(lbl_pagecurent)
GridView1.DataSource = page;//前后两句都是用来绑定数据源的
GridView1.DataBind();
//lbl_pagecurent当前第几页 lbl_count总共第几页
//LinkButton1首页 btn_prev上一页 btn_next下一页
//LinkButton4末页 TextBox2 跳转到第几页
if (pagecurent==1)
{
btn_prev.Enabled = false;
}
else
{
btn_prev.Enabled = true;
}
if (pagecurent==page.PageCount)
{
btn_next.Enabled = false;
}
else
{
btn_next.Enabled = true;
}
}
protected void btn_prev_Click(object sender, EventArgs e)
{
int i = int.Parse(this.lbl_pagecurent.Text) - 1;
this.lbl_pagecurent.Text = i.ToString();
pagesize();
}
protected void btn_next_Click(object sender, EventArgs e)
{
int i = int.Parse(this.lbl_pagecurent.Text) + 1;
this.lbl_pagecurent.Text = i.ToString();
pagesize();
}
protected void LinkButton1_Click(object sender, EventArgs e)
{
lbl_pagecurent.Text = "1";
pagesize();
}
protected void LinkButton4_Click(object sender, EventArgs e)
{
lbl_pagecurent.Text = this.lbl_count.Text;
pagesize();
}
protected void Button3_Click(object sender, EventArgs e)
{
this.lbl_pagecurent.Text = this.TextBox2.Text;
pagesize();

这是分页的整个源代码,有的括号掉了,你自己去看一下吧

参考资料: asp教材

景愉玉幼霜
2019-01-31 · TA获得超过3784个赞
知道大有可为答主
回答量:3163
采纳率:30%
帮助的人:174万
展开全部
分页,一般有两种方式,一个是在数据库引擎中分页,比如利用存储过程。
一个是在业务逻辑中分页,这样可以兼顾多种控件,而不局限于一种或者几种UI。
我给出两种原型,你自己选择适合自己的方式,对于性能测试,我也提供一下测试图例。
实践原型:
http://hi.baidu.com/44498/blog/item/3a20a4167de88c4021a4e9d5.html
性能测试:
http://hi.baidu.com/44498/blog/item/19f870dd2b65d03d5882dd63.html
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
QQ2k5
2009-10-22 · TA获得超过438个赞
知道小有建树答主
回答量:911
采纳率:25%
帮助的人:261万
展开全部
在page_onclick中
先判断CommandName的值
string strCommand = ((Button)sender).CommandArgument.ToString();
用viewstate["currentpage"]储存button时间后的页数

然后在datalistbind()中,ps.currentpage来获取当前的页数

具体详情,请参照我以前的回答
http://zhidao.baidu.com/question/98224755.html
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
千奕森良才
2019-01-03 · TA获得超过4044个赞
知道大有可为答主
回答量:3106
采纳率:25%
帮助的人:220万
展开全部
//
数据源
PagedDataSource
Pgds=new
PagedDataSource();
//
Pgds.DataSource=CreateDataSource().DefaultView;
//
设置允许分页
Pgds.AllowPaging=true;
//
每页显示为2行
Pgds.PageSize=2;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
成掣零鸾
2019-11-10 · TA获得超过3988个赞
知道大有可为答主
回答量:3141
采纳率:34%
帮助的人:203万
展开全部
可以用pagedatasource
这个类!对数据进行分页操作!
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式