数据绑定不刷新Gridview

时间:2011-07-06 13:36:11

标签: c# asp.net data-binding gridview postback

我有一个gridview,我在代码隐藏中动态地数据绑定。出于某种原因,并且仅当用户从gridview中删除一行(使用自定义函数)时,在回发后,gridview不会刷新(删除的值仍然存在)。但是,如果用户要以任何其他方式刷新gridview(即添加项目,在另一个选项卡中选择正确的项目等),它就可以正常运行。

我在代码隐藏中放置断点以查看发生了什么,显然gridview正确绑定,并且删除的项目不在gridview.DataSource中。

这是我的代码,所以如果你看到我没有,请告诉我!

删除行命令:

if (e.CommandName == "delete")
        {
            int selectedId = int.Parse(e.CommandArgument.ToString());
            //delete selected row from database
            var item = (Item)DataContext.Items.Where(item => item.ItemId == selectedId).Single();
            if (item != null)
            {
                DataContext.CompanyGoalPrograms.DeleteObject(item);
            }
            DataContext.SaveChanges();

            bindGridView(currentId); //firing, but not refreshing gv after postback
            // currentId is a static variable
        }

bindGridView 方法(每隔一次调用它的工作方式,所以我认为问题不在这里):

protected void bindGridView(long thisId)
    {
        var query = from items in DataContext.Items
                    where items.SubSomething.Something.SomethingId == thisId && goals.SubSomething.YearId == selectedYearId //<--another static variable
                    select items;
        Gridview1.DataSource = from items in query.AsEnumerable()
                                    select new
                                    {
                                        items.Field1,
                                        items.Field2,
                                        items.Field3,
                                        Field4 = ((decimal)items.Field4).ToString("N2"),
                                        Field5 = ((decimal)items.Field5).ToString("N2"),
                                        Field6 = String.Format("{0:#,##0}", (long)items.Field6),
                                        Field7 = items.Field4 == null ? "$0.00" : ((decimal)items.Field7).ToString("C"),
                                    };
        Gridview1.DataBind();
     }

[编辑] 有趣的是,它不仅运行,而且当我运行数据源(调试时)后检查数据源的内容时,实际删除的项目从数据源中删除<​​/ em>,它只是不会向用户显示更改。

3 个答案:

答案 0 :(得分:5)

我发现了问题:

Gridviews具有预定义的命令设置,例如“选择”,“编辑”和“删除”。当我尝试使用命令名称“delete”来定义我自己的事件时,程序将尝试运行我的事件的一部分以及它的预定义事件。这就是造成问题的原因。

答案 1 :(得分:1)

这完全是我的问题。我传递“删除”作为asp:ImageButton的CommandName。在我看到你的帖子之后我改变它以通过“DeleteThis”并立即开始工作。像这样的保留字问题....!

感谢您在事后发布解决方案。它至少帮助了一个人。

Victor Del Prete

答案 2 :(得分:0)

bindgridview肯定会运行吗?你是否在调试模式下运行它来验证?