菜鸟实在找不出问题出在哪里了,已经奄奄一息,各位神,救命吧!!!

爱_逆光 2013-09-08 12:07:55
Datalist控件利用PagedDataSource做分页,从首页开始按下一页按钮按到第二下就岿然不动了。这时候是在第二页,当按上一页按钮返回的时候又出现“索引-5不是为负数就是大于行数”,按尾页按钮出现同样的索引问题。
我的项目思路是这样:

1、一个留言板,利用Datalist控件把数据表中的数据读取过来并显示。
2、利用分页控件PagedDataSource进行分页。
3、页面Page_Load事件中调用自定义函数bangding(int currentpage);
4、函数bangding(int currentpage)里定义PagedDataSource的各项属性
pds.AllowPaging = true;
pds.PageSize = 5;
pds.CurrentPageIndex = currentpage;
5、函数参数currentpage用来传递分页按钮传递过来的CurrenPageIndex的值。

下面,勇敢的贴出菜鸟代码

1、留言前台页面

<h1>简易留言板</h1>
<asp:DataList ID="DataList2" runat="server" OnItemCommand="DataList2_ItemCommand">
<ItemTemplate>
<div id="liuyan">
<div id="fu">
<div id="zuo"><%--前台留言板左右两列布局,这里是左,显示昵称头像等。--%>
<ul>
<li class="li1">昵称:<%# Eval("name")%></li>
<li class="li1">QQ:<%# Eval("qq") %></li>
<li class="li1">头像:<asp:Image ID="Image1" runat="server" ImageUrl='<%# Eval("touxiang")%>'/></li>
<li class="li1"><marquee><%# Eval("name")%></marquee></li>
</ul>
</div>
<div id="youu"><%--前台留言板左右两列布局,这里是右边,显示用户发的文字。--%>

<%# Eval("content") %>
</div>
</div>
</div>
</ItemTemplate>
<FooterTemplate><%--以下是分页的四个按钮,首页上一页下一页尾页,在分页的四个按钮中都加入CommandName属性,为后台cs文件的ItemCommand事件传递字符。--%>
<asp:LinkButton ID="LinkButton1" class="linkbutton" runat="server" CommandName="first">首页</asp:LinkButton>
<asp:LinkButton ID="LinkButton2" class="linkbutton" runat="server" CommandName="pre">上一页</asp:LinkButton>
<asp:LinkButton ID="LinkButton3" class="linkbutton" runat="server" CommandName="next">下一页</asp:LinkButton>
<asp:LinkButton ID="LinkButton4" class="linkbutton" runat="server" CommandName="last">尾页</asp:LinkButton>

</FooterTemplate>
</asp:DataList>


2、留言的cs文件

public partial class Default3 : System.Web.UI.Page
{
PagedDataSource pds = new PagedDataSource();//实例化分页类。
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
bangding(0);
}
}
//下面是自定义函数bangding()
private void bangding(int currentpage)
{

pds.AllowPaging = true;
pds.PageSize = 5;
pds.CurrentPageIndex = currentpage;
string str = "Data Source=CHUNCHUN;Database=tb_newss;User ID=sa;Password=123321";
SqlConnection mon = new SqlConnection(str);
mon.Open();
string oo = "select * from Table_1 ";
SqlDataAdapter da = new SqlDataAdapter(oo, mon);
DataSet ds = new DataSet();
da.Fill(ds);
pds.DataSource = ds.Tables[0].DefaultView;
DataList2.DataSource = pds;
DataList2.DataBind();
mon.Close();
}

//下面是分页按钮的ItemCommand事件。
protected void DataList2_ItemCommand(object source, DataListCommandEventArgs e)
{
switch (e.CommandName)
{
case"first":
pds.CurrentPageIndex = 0;
bangding(pds.CurrentPageIndex);
break;
case "pre":
pds.CurrentPageIndex = pds.CurrentPageIndex-1;
bangding(pds.CurrentPageIndex);
break;
case "next":
pds.CurrentPageIndex = pds.CurrentPageIndex+1;
bangding(pds.CurrentPageIndex);
break;
case "last":
pds.CurrentPageIndex = pds.PageCount-1;
bangding(pds.CurrentPageIndex);
break;

}
}
}


...全文
542 20 打赏 收藏 转发到动态 举报
写回复
用AI写文章
20 条回复
切换为时间正序
请发表友善的回复…
发表回复
narutocandy 2013-09-09
  • 打赏
  • 举报
回复
我也不懂,来学习一下~
令狐苦瓜 2013-09-09
  • 打赏
  • 举报
回复
坐看两神对喷
爱_逆光 2013-09-09
  • 打赏
  • 举报
回复
引用 12 楼 sp1234 的回复:
[quote=引用 8 楼 love_love_yyou 的回复:] 奥,原来是这样。我根据您说的方法,我把PagedDataSource类定义成静态全局的,问题解决了。
我没有跟你说过static。 我告诉你的是,页面范畴的状态是要在ViewState中保持的。因此 pds.CurrentPageIndex 需要设计为当前页面实例范畴的。 比如说
public int CurrentPageIndex
{
    get{ return (int)(ViewState["pIndex"]??0); }
    set{ ViewState["pIndex"]=value; }
}
你应该用这个 CurrentPageIndex 属性来记录当前的页号。在你的 private void bangding(int currentpage) 写一行
    CuttrentPageIndex = currentPage;
                pds.CurrentPageIndex = pds.CurrentPageIndex+1;
                bangding(pds.CurrentPageIndex);
这种语句应该改为
                               bangding(CurrentPageIndex + 1);
[/quote] 虽然还是不太懂您说的这些,不过我想,我现在遇到的一个问题应该就是您说的这个回传值的问题。我在前台加了一个Label,为了获取每次点击分页按钮时pds.CurrenPageInex的值,但是情况很糟糕,显示的值很错乱,一会儿为“1”,一会儿就是别的数字了。。。。
爱_逆光 2013-09-09
  • 打赏
  • 举报
回复
引用 13 楼 sp1234 的回复:
其实正好在你扯上“sql分页”时,你是不是更加需要懂得如何在回发(上一页、下一页)的时候取得 CurrentPageIndex 的知识呢? 你看哪个嚷嚷着让你邯郸学步的“必须现在就sql分页”的说法,告诉你如何正确地取得 CurrentPageIndex 的值了吗? 时髦的说法其实谁都会说。但是我们看到了“邯郸学步”根本无用,知道你必须先学会ViewState来处理你的ItemCommand事件中的回发求CurrentPageIndex值得问题,才会告诉你那个说法“跟你这个问题没有直接关系”的。这里谈的才是有关系、必须先知道的知识。只有知道如何计算 CurrentPageIndex,你才可能不被别的什么时髦说法所害。
真心谢谢,受益匪浅,谢谢!
F15Eagle 2013-09-09
  • 打赏
  • 举报
回复
ViewState是楼主当前解决问题的钥匙,但楼主开发思路还是有很大的问题。
爱_逆光 2013-09-08
  • 打赏
  • 举报
回复
引用 3 楼 sp1234 的回复:
呵呵,例如 pds.CurrentPageIndex = pds.CurrentPageIndex-1 这句如果真的执行到这里,那么你永远都是得到 -1。而 pds.CurrentPageIndex = pds.CurrentPageIndex+1 永远都得到 1。因为你的 pds 都是刚刚重新初始化来的! 如果要这么麻烦地去使用分页功能,那么你至少需要在ViewState上有 CurrentPageIndex 值,而不是 pds。
大神就是大神,精辟,去试试!!!
  • 打赏
  • 举报
回复
呵呵,例如 pds.CurrentPageIndex = pds.CurrentPageIndex-1 这句如果真的执行到这里,那么你永远都是得到 -1。而 pds.CurrentPageIndex = pds.CurrentPageIndex+1 永远都得到 1。因为你的 pds 都是刚刚重新初始化来的! 如果要这么麻烦地去使用分页功能,那么你至少需要在ViewState上有 CurrentPageIndex 值,而不是 pds。
threenewbee 2013-09-08
  • 打赏
  • 举报
回复
你说的一系列症状说明PagedDataSource没有数据 你应该先查询绑定再指定PageIndex,在你的bangding方法中。 参考 http://3941954.blog.51cto.com/3931954/791488 的写法。
  • 打赏
  • 举报
回复
PagedDataSource pds = new PagedDataSource();//实例化分页类。 每一次回发,都创建pds实例吗?
moonwrite 2013-09-08
  • 打赏
  • 举报
回复
要想成功 努力是必不可少的 但要加快成功的时间 就要向成功的人学习 来减少弯路 那么请问sp1234 那些php jsp js.node ruby....等程序员在没有PagedDataSource可以使用的情况下 他们是怎么实现分页的呢~ 还不是直接数据库分页~ 当年微软就不应该搞个PagedDataSource这个丑陋的东西出来 现在有泛型的情况下,你还会去学集合么~
  • 打赏
  • 举报
回复
其实正好在你扯上“sql分页”时,你是不是更加需要懂得如何在回发(上一页、下一页)的时候取得 CurrentPageIndex 的知识呢? 你看哪个嚷嚷着让你邯郸学步的“必须现在就sql分页”的说法,告诉你如何正确地取得 CurrentPageIndex 的值了吗? 时髦的说法其实谁都会说。但是我们看到了“邯郸学步”根本无用,知道你必须先学会ViewState来处理你的ItemCommand事件中的回发求CurrentPageIndex值得问题,才会告诉你那个说法“跟你这个问题没有直接关系”的。这里谈的才是有关系、必须先知道的知识。只有知道如何计算 CurrentPageIndex,你才可能不被别的什么时髦说法所害。
  • 打赏
  • 举报
回复
引用 8 楼 love_love_yyou 的回复:
奥,原来是这样。我根据您说的方法,我把PagedDataSource类定义成静态全局的,问题解决了。
我没有跟你说过static。 我告诉你的是,页面范畴的状态是要在ViewState中保持的。因此 pds.CurrentPageIndex 需要设计为当前页面实例范畴的。 比如说
public int CurrentPageIndex
{
    get{ return (int)(ViewState["pIndex"]??0); }
    set{ ViewState["pIndex"]=value; }
}
你应该用这个 CurrentPageIndex 属性来记录当前的页号。在你的 private void bangding(int currentpage) 写一行
    CuttrentPageIndex = currentPage;
                pds.CurrentPageIndex = pds.CurrentPageIndex+1;
                bangding(pds.CurrentPageIndex);
这种语句应该改为
                               bangding(CurrentPageIndex + 1);
  • 打赏
  • 举报
回复
如果连状态 pds.CurrentPageIndex 怎样保持一致都没有搞懂,又掉头搞什么“sql分页”,这岂不陷入那“成事不足败事有余”的怪圈里去了?! 还是先把在使用pds组件进行分页下的这个程序搞懂,再去搞别的东西吧。 我告诉你一个基本道理,真正的技术是“一小步一小步”去重构的,也就是说你的代码应该仅仅修改两三行代码先让它完全实现,然后才会因为性能问题(仅仅在将来确实有证据证明已经出现了性能问题)才重构。 没有说一个事情不成,就推倒了去学另外一个事情的。邯郸学步的结果必定是在浅表的层面上行走,哪个都没有学会。
爱_逆光 2013-09-08
  • 打赏
  • 举报
回复
引用 9 楼 moonwrite 的回复:
[quote=引用 8 楼 love_love_yyou 的回复:] [quote=引用 7 楼 sp1234 的回复:] [quote=引用 6 楼 love_love_yyou 的回复:] [quote=引用 5 楼 moonwrite 的回复:] 还是学学怎么在数据库层面分页吧~ 把所有数据加载到内存再分页 是不科学的~
不懂啊,怎么在数据库层面分页?我应该学习些什么? [/quote] 跟你这个问题没有直接关系。他是说你的代码 string oo = "select * from Table_1 " 这里可以仅返回5条记录,而不是返回所有记录。这是sql语句问题,跟你的“翻页时的 pds.CurrentPageIndex 赋值语句值出错”没有直接关系。[/quote] 奥,原来是这样。我根据您说的方法,我把PagedDataSource类定义成静态全局的,问题解决了。您太厉害了!!!万分万万分感谢。。。。。。。。[/quote] 关系大了,PagedDataSource是从数据库加载数据后才分页的(十分浪费内存),你说正式的工作中有那几个用到了PagedDataSource,sp1234不是很喜欢噴用控件的人的么~,怎么这次不好好地说说这个小菜鸟~ 知道实体的概念+linq后,PagedDataSource根本就没有学习和使用的价值了 你知道用静态使用的后果么~ 你现在模拟多用户浏览你做的这个页面, 用户A,点击第二页后,用户B刷新页面看看~ 两个页面的数据应该相同~但用户B只是想刷新页面~ 就算两个用户页面不同 但PagedDataSource永远不会被释放~ 关于数据库层分页 搜索: sql分页~[/quote] 我发现你们对程序在底层怎么跑非常清楚,比如你说在内存分页很浪费。我怎么不清楚这些,还有你说什么实体+linq什么的。哎,不知道的东西怎么这么多。。。。要怎么才能达到既能实现效果又能知道底层的运行从而优化代码。看来,任重道远。。。
moonwrite 2013-09-08
  • 打赏
  • 举报
回复
引用 8 楼 love_love_yyou 的回复:
[quote=引用 7 楼 sp1234 的回复:] [quote=引用 6 楼 love_love_yyou 的回复:] [quote=引用 5 楼 moonwrite 的回复:] 还是学学怎么在数据库层面分页吧~ 把所有数据加载到内存再分页 是不科学的~
不懂啊,怎么在数据库层面分页?我应该学习些什么? [/quote] 跟你这个问题没有直接关系。他是说你的代码 string oo = "select * from Table_1 " 这里可以仅返回5条记录,而不是返回所有记录。这是sql语句问题,跟你的“翻页时的 pds.CurrentPageIndex 赋值语句值出错”没有直接关系。[/quote] 奥,原来是这样。我根据您说的方法,我把PagedDataSource类定义成静态全局的,问题解决了。您太厉害了!!!万分万万分感谢。。。。。。。。[/quote] 关系大了,PagedDataSource是从数据库加载数据后才分页的(十分浪费内存),你说正式的工作中有那几个用到了PagedDataSource,sp1234不是很喜欢噴用控件的人的么~,怎么这次不好好地说说这个小菜鸟~ 知道实体的概念+linq后,PagedDataSource根本就没有学习和使用的价值了 你知道用静态使用的后果么~ 你现在模拟多用户浏览你做的这个页面, 用户A,点击第二页后,用户B刷新页面看看~ 两个页面的数据应该相同~但用户B只是想刷新页面~ 就算两个用户页面不同 但PagedDataSource永远不会被释放~ 关于数据库层分页 搜索: sql分页~
爱_逆光 2013-09-08
  • 打赏
  • 举报
回复
引用 7 楼 sp1234 的回复:
[quote=引用 6 楼 love_love_yyou 的回复:] [quote=引用 5 楼 moonwrite 的回复:] 还是学学怎么在数据库层面分页吧~ 把所有数据加载到内存再分页 是不科学的~
不懂啊,怎么在数据库层面分页?我应该学习些什么? [/quote] 跟你这个问题没有直接关系。他是说你的代码 string oo = "select * from Table_1 " 这里可以仅返回5条记录,而不是返回所有记录。这是sql语句问题,跟你的“翻页时的 pds.CurrentPageIndex 赋值语句值出错”没有直接关系。[/quote] 奥,原来是这样。我根据您说的方法,我把PagedDataSource类定义成静态全局的,问题解决了。您太厉害了!!!万分万万分感谢。。。。。。。。
  • 打赏
  • 举报
回复
引用 6 楼 love_love_yyou 的回复:
[quote=引用 5 楼 moonwrite 的回复:] 还是学学怎么在数据库层面分页吧~ 把所有数据加载到内存再分页 是不科学的~
不懂啊,怎么在数据库层面分页?我应该学习些什么? [/quote] 跟你这个问题没有直接关系。他是说你的代码 string oo = "select * from Table_1 " 这里可以仅返回5条记录,而不是返回所有记录。这是sql语句问题,跟你的“翻页时的 pds.CurrentPageIndex 赋值语句值出错”没有直接关系。
爱_逆光 2013-09-08
  • 打赏
  • 举报
回复
引用 5 楼 moonwrite 的回复:
还是学学怎么在数据库层面分页吧~ 把所有数据加载到内存再分页 是不科学的~
不懂啊,怎么在数据库层面分页?我应该学习些什么?
moonwrite 2013-09-08
  • 打赏
  • 举报
回复
还是学学怎么在数据库层面分页吧~ 把所有数据加载到内存再分页 是不科学的~

62,074

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧