今天遇到一件奇怪的事情。一个同事做了一个新页面(是从别的页面拷贝过来,然后修改的)。发现触发DropDownList空间的SelectedIndexChange事件之后,页面回发了,但是没有进入相应的时间处理函数。一个简单的问题捣鼓了好几个小时,最后终于解决了。
调查经历了几个阶段:
阶段一:怀疑是设置不对。检查了DropDownList的AutoPostback,其设置为true,正确;
阶段二:怀疑是数据绑定不对。这个做了很多试验,考虑是每次绑定还是放到第一次加载。最后发现原来放到第一次加载的地方是对的。
阶段三:怀疑是局部刷新的问题。注释掉所有关于ScriptManager,UpdatePanel的东西,发现问题一点都没有解决。
阶段四:怀疑还是设置不对。看到form控件里边参数很多,索性全部删除了,一运行,好了。不断缩小范围,发现是EnableViewState在捣乱,它被设置成false了,默认应该是true。
问题是解决了,但是为什么EnableViewState会被设置成false呢?我们查了原始页面,确实是false。于是学习了一下EnableViewState属性。发现官方的解释是,设置成false以后,页面的数据就不向服务器发送,减轻数据流量,提高效率。就是说,回送以后的逻辑,跟现在界面的控件值无关。这个很有用,特别是你现在的界面数据量很大,而你要得到的新数据又跟当前数据关系不大得时候。其实这个时候还是有办法向服务器提交数据的,就是使用隐藏域,隐藏域总是会被回送的。
又学习了一招