ASP.NET Ajax 调试技巧:用 FireBug 调试 UpdatePanel 不更新问题

今天有一个人询问我 UpdatePanel 不更新的问题,他在 Fiddler 里面已经看到传递的数据了,但是搞不明白为什么没有更新。那么这个时候就要调试到脚本中去,看看到底发生了什么。我用的是 FireBug,情况如下图:

aspnetajax_debug.JPG

图中当前页面引用了两个 ScriptResource.xsd 脚本文件,其内容是系统生成的 js 脚本:

MicrosoftAjax.js
MicrosoftAjaxWebForms.js

在 MicrosoftAjaxWebForms.js 中有下列一些关键代码,可以用 FireBug 在这些地方下断点查看 UpdatePanel 更新的细节过程。

1316行:  updatePanelElement.innerHTML = rendering;

注意这个语句是针对某一个特定的 updatePanel,所以如果回发后有多个 panel 要更新,则会多次跑到这个断点处。


这个语句的调用堆栈大致是:

1087行: this._updatePanel(updatePanelElement, deltaPanelRendering);
859行:     
function Sys$WebForms$PageRequestManager$_onFormSubmitCompleted(sender, eventArgs) {

基本上客户端的问题如果找不到出错原因,从 859行开始单步调试就能搞清楚了。


如果页面不能在 FireFox 中正常呈现,非要用 IE 调试,也是可以的。用 Visual Studio 2005 进入调试状态后,选择菜单里面的 Debug -> Windows -> Script Explorer 就可以看到所有脚本资源了,打开后一样可以下断点。

如下图所示:
aspnetajax_debug_vs.JPG

posted on 2007-07-26 17:12  NeilChen  阅读(3173)  评论(10编辑  收藏  举报

导航