2012-08-15 106 views
2

我使用我的自定义DataTable作为DataSource以我的ListView。现在,我面临的问题是Paging不起作用。带分页的自定义数据表

我想要做的是,当我点击页面12等等,我应该能够一次只取10行。

我的意思是,当页面加载时,我只想抓取前10行,点击2我想抓取下10行。但是回到页面1不应该再次执行SQL语句,只是从某处获取数据(ViewState/Cache)。

什么是正确的方法?我应该如何继续?

注:我不想使用SQL DataSource

回答

0

你需要的是一个PagingDataSource ...

protected void Page_Load(object sender, EventArgs e) 
{ 
    BindData((hdnPage.Value != "" ? Convert.ToInt32(hdnPage.Value) : 0)); 
} 

private void BindData(int? pageNo) 
{ 
    PagedDataSource ds = new PagedDataSource(); 
    ds.DataSource = [YOUR DATA SOURCE]; 
    ds.AllowPaging = true; 
    ds.PageSize = 10; 
    ds.CurrentPageIndex = pageNo ?? 0; 

    pnlPaging.Controls.Clear(); 
    for (int i = 0; i < ds.PageCount; i++) 
    { 
     if (ds.PageCount < 2) 
     { 
      break; 
     } 

     if (pageNo == i || (pageNo == null && i == 0)) 
     { 
      pnlPaging.Controls.Add(new LiteralControl("<span style=\"display:inline-block;margin:0 2px 2px 0;\">" + (i + 1).ToString() + "</span>")); 
      continue; 
     } 

     SuprLinkButton lb = new SuprLinkButton() 
     { 
      CommandName = "pageThis", 
      CommandArgument = i.ToString(), 
      ID = "lbPage" + i.ToString(), 
      Text = (i + 1).ToString() 
     }; 
     lb.Attributes.Add("style", "display:inline-block;margin:0 2px 2px 0;"); 
     lb.Command += new CommandEventHandler(lb_Command); 
     pnlPaging.Controls.Add(lb); 
    } 

    [LISTVIEW].DataSource = ds; 
    [LISTVIEW].DataBind(); 
} 

我有一个小组来保存所有网页链接和hiddenfield保存当前页面索引。然后是分页命令...

protected void lb_Command(object sender, CommandEventArgs e) 
{ 
    hdnPage.Value = e.CommandArgument.ToString(); 
    BindData(Convert.ToInt32(e.CommandArgument)); 
} 
+1

感谢您的答复..可以给我完整的例子..所以我更容易理解,因为我是ASP.NET新手..如果你有这个项目......你可以把它放在什么地方? – user1593175 2012-08-15 17:54:24

+0

不幸的是我不能承载这个项目,但我确实更新了我的答案。您有初始绑定发生的页面加载(调用BindData)和分页命令。您只需在前端添加一个面板和隐藏字段(pnlPaging,hdnPage),然后用您的数据表替换[您的数据源]并用列表视图的ID替换[LISTVIEW]。 – CoderMarkus 2012-08-15 18:02:53

+1

好的,谢谢,还有一件事...在DataTable中我应该从表中取出所有的行吗?即'SELECT * FROM TABLT-NAME' – user1593175 2012-08-15 18:05:10