April 2006
English Version: http://dflying.dflying.net/1/archive/115_atlas_client_side_javascript_debugging.html
应用于:
Microsoft ASP.NET 2.0
Microsoft ASP.NET Atlas March CTP
Microsoft Visual Studio 2005
介绍
编写Atlas的JavaScript脚本将比编写C# 更具有挑战性,因为JavaScript没有编译时期检查,在编码时候也没有智能感知提示。并且您还需要在运行时跟踪服务器和客户端的网络通信。而且目前还没有一个非常强大的JavaScript IDE可以帮您分担其中繁杂的工作。
我在工作中使用Atlas有半年左右,其中积累了一些关于调试Atlas程序得知识与经验,希望能与大家分享。其中疏漏之处,还请多多指正。
捕获HTTP通信内容
在任何的AJAX程序开发中,监视服务器与客户端的通信内容都是非常重要的。这样您可以得知我实际上像服务器发送了什么以及服务器实际上给我返回了什么。当您的Atlas程序遇到问题时,首先要考虑的就是查看一下客户端与服务器端的通信,看看通信的内容是不是您所期盼的。
这里我推荐的工具是Fiddler(可以在http://www.fiddlertool.com/fiddler/下载)。Fiddler是一个HTTP调试的代理,它可以记录您的计算机和Internet之间HTTP通信的全部内容(包括header,cookie,通信内容等),设置断点,修改传入/传出的数据等。Fiddler比NetMon或Achilles等同类软件简单得多,并且提供了一个简单但强大的基于JScript.NET的事件的脚本子系统。Fiddler支持Internet Explorer以及其它浏览器。
使用Atlas Debug Helper Class
如果您的Atlas程序运行在debug模式下,那么Atlas会自动为您生成一个Debug Helper Class。 这个Debug Helper Class是一个全局的对象,名称为debug,可以在您代码的任何部位被访问到。使用这个debug对象的方法,您可以在运行时dump一个对象(以可读的形式在页面尾部显示该对象的内部状态),显示trace信息,使用断言(assertion),break到调试器等。如果Visual Studio的脚本调试器(参见下文)已经attach到了这个Internet Explorer上,那么Visual Studio的Output窗口也会显示trace信息。
这个Debug Helper Class提供如下方法:
演示如何使用debug.dump()请见参考文档
将Visual Studio 脚本调试器attach到Internet Explorer
您可以使用Visual Studio脚本调试器来调试您的JavaScript代码。虽然这个调试器功能有限且有许多bug,不过我觉得它已经是此刻市面上最好的JavaScript调试器了。您需要安装Visual Studio 2005以及 Internet Explorer 6.0或以上版本来使用Visual Studio脚本调试器。
在默认情况下,Internet Explorer将忽略所有JavaScript脚本错误。您需要手动设置一些属性来使Internet Explorer启用调试功能。打开Internet Explorer窗口,在Tools菜单下选择Internet Options,在Advanced标签中,不要选中Disable Script Debugging (Internet Explorer)和Disable Script Debugging (Other)两项,并选中Display a notification about every script error一项。
您需要attach调试器到Internet Explorer进程上以开始debug。在Visual Studio中使用F5来启动调试即可。还有一种方法,您可以将Visual Studio脚本调试器attach到已经在运行的某个Internet Explorer进程上:在Internet Explorer的View菜单下,展开Script Debugger菜单项,选择Open。然后在弹出的对话框中选择一个正在运行的Visual Studio或是另外启动一个Visual Studio。
脚本调试器使用技巧以及现存Bug
调试Atlas应用程序时,应该注意以下问题:
参考资源