首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在ASP.NET GridView控件中维护行选择

在ASP.NET GridView控件中维护行选择
EN

Stack Overflow用户
提问于 2012-02-01 21:49:28
回答 2查看 2.4K关注 0票数 1

设置:我目前使用SqlDataSource在更新面板中有一个带有GridView控件的页面。我有一个计时器设置,每X秒更新一次GridView。通常我测试的是,每次gridview更新时,大约4-5行新数据被添加到网格视图中,而最后4-5行数据被丢弃。我一次只显示15个结果,每次更新都会有新的结果。

问题:我允许用户在更新GridView时选择行。我通过设置SelectedIndex属性来处理这个问题。但是,当我选择一行,然后更新网格时,用户选择的行会被下推大约4-5行,而之前选择的索引中的数据会被选中。所以他们点击的地方是在这一点上选择的,而不是他们点击的内容。

我需要一种方法来确定,如果可能的话,从SqlDataSource/Gridview中确定有多少新行添加到了网格视图中。或者一种通过行中的数据而不仅仅是SelectedIndex来维护所选数据的方法。

感谢您的帮助,谢谢。

已解决:好了,我继续往网格中添加了一个新的不可见列,现在跟踪从数据库中选择的唯一ID。通过在数据绑定之前设置一个数组,并将其与数据绑定后获得的新数组进行比较,我能够使用一个简单的Intersect来确定相同的行数。然后,我用它来从总数中确定这个回发有多少是新的。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-02-01 21:52:05

这只是一个想法:

我认为可以使用不可见的列(更具体地说是ID列)在Session对象中存储所选行的IDs值,然后在网格更新之后,可以检索此值并再次选择行(如果它们仍然存在)。

票数 1
EN

Stack Overflow用户

发布于 2012-02-01 22:06:57

如果您有自定义GridView OnRowUpdating事件。

代码语言:javascript
复制
public void GridView_RowUpdating(object sender, GridViewUpdateEventArgs e)
{
    Session["CurrIndex"] = GridView.SelectedIndex;//index before insertion
    Session["RowCount"] = GridView.Rows.Count;//row count before insertion
    //Add new Rows
    GridView.SelectedIndex = (Int32)(Session["CurrIndex"]) + ( GridView.Rows.Count - (Int32)(Session["RowCount"]);//update selected index
    Session["CurrIndex"] = GridView.SelectedIndex;//restore the index into session
}  
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9096844

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档