代码改变世界

第一次用ListView,就抓到BUG。

2008-02-20 02:47  无常  阅读(3283)  评论(10编辑  收藏  举报

事发于ListView.EditItem 属性

MSDN对此属性的解释:

类型:System.Web.UI.WebControls.ListViewItem

ListView 控件中处于编辑模式的项;或者,如果没有项处于编辑模式,则为 null。

 

事发过程

我的页面是这样子的:

image

在ListView中嵌套一个Repeater控件显示和编辑子表数据。

因为在Update的时候ListView不会帮我更新Repeater中的数据,所以我需要在ItemUpdating事件中找到Repeater控件,再通过Repeater控件FindControl找到每行的数据。

按MSDN的说法,我可以这样做:

    protected void ListView1_ItemUpdating(object sender, ListViewUpdateEventArgs e)
    {
        Repeater repeater = ListView1.EditItem.FindControl("Repeater1") as Repeater;
        //....
    }

这样基本没问题,除非Update的是ListView的第一行

如果Update第一行,虫子就出现了。

image

启动Debug,看下,EditItem==null ???

image

不管是转到第几页,就是只在更新第一行时出错

如果Updata的不是第一行,那就没什么问题。

没折了,只能绕个圈子,通过this.ListView1.Items[e.ItemIndex]来FindControl

image

 

没办法,祭出Reflctor,打开System.Web.Extensions, Version=3.5.0.0程序集,找到System.Web.UI.WebControls.ListView.EditItem. Desassemble->

image

 

问题出在这里了,看红圈圈部分,如果编辑ListView的第一行时,EditIndex是0,而EditItem的实现竟然是判断大于0 :(

顺便看下EditIndex的实现

image

这个没什么问题了,如果设置值小于-1时就出错,=-1就认为是结束编辑状态。

 

难得第一次用ListView就遇到这种BUG。

MS的工程师也太粗心了。

 

附上个测试例子

ListViewBugTest.rar