Javascript的调试,是开发Web应用尤其是AJAX应用很重要的一环,目前对Javascript进行调试的工具很多,我比较喜欢使用的是Firebug。Firebug是Joe Hewitt开发的一套与Firefox集成在一起的功能强大的web开发工具,可以实时编辑、调试和监测任何页面的CSS、HTML和JavaScript。
本文主要是为初学者介绍一下Firebug的基本功能与如何使用Firebug。由于本人水平与能力有限,在文章中的可能会有很多错误与遗漏,希望大家能谅解和指正!
1、 安装
Firebug是与Firefox集成的,所以我们首先要安装的事Firefox浏览器。安装好浏览器后,打开浏览器,选择菜单栏上的“工具”菜单,选择“附加软件”,在弹出窗口中点击右下角的“获取扩展”链接。在打开的页面的search输入框中输入“firebug”。等搜索结果出来后点击Firbug链接(图1-1红色圈住部分)进入Firebug的下载安装页面。
|
图1-1
|
在页面中点击Install Now(图1-2)按钮。
|
图1-2
|
在弹出窗口(图1-3)中等待3秒后单击“立即安装”按钮。
|
图1-3
|
等待安装完成后会单击窗口(图1-4)中的“重启 Firefox”按钮重新启动Firefox。
|
图1-4
|
当Firefox重启完后我们可以在状态栏最右边发现一个灰色圆形图标(),这就表示Firebug已经安装好了。灰色图标表示Firebug未开启对当前网站的编辑、调试和监测功能。而绿色()则表示Firebug已开启对当前网站进行编辑、调试和监测的功能。而红色图标()表示已开启对当前网站进行编辑、调试和监测的功能,而且检查到当前页面有错误,当前图标表示有5个错误。
2、 开启或关闭Firebug
单击Firebug的图标或者按F12键你会发现页面窗口被分成了两部分,上半部分是浏览的页面,下半部分则是Firebug的控制窗口(图2-1)。如果你不喜欢这样,可以按CTRL+F12或在前面操作后单击右上角的上箭头按钮,弹出一个新窗口作为Firebug的控制窗口。
|
图2-1
|
从图2-1中我们可以看到,因为我们开启Firebug的编辑、调试和监测功能,所以目前只有两个可以选择的链接:“Enable Firebug”与“Enable Firebug for this web site”。如果你想对所有的网站进行编辑、调试和检测,你可以点击“Enable Firebug”开启Firebug,则以后无论浏览任何网站,Firebug都处于活动状态,随时可以进行编辑、调试和检测。不过一般的习惯我们只是对自己开发的网站进行编辑、调试和检测,所以我们只单击“Enable Firebug for this web site”开启Firebug就行了。
开启Firebug窗口(图2-2)后,我们可以看到窗口主要有两个区域,一个是功能区,一个是信息区。选择功能区第二行的不同标签,信息区的显示会有不同,Options的选项也会不同,搜索框的搜索方式也会不同。
|
图2-2
|
要关闭Firebug控制窗口单击功能区最右边的关闭图标或按F12键就行了。如果要关闭Firebug的编辑、调试和监测功能,则需要单击功能区最左边的臭虫图标,打开主菜单,选择“Disable Firebug”或“Disable Firebug for xxxxx”。
3、 Firebug主菜单
单击功能区最左边的臭虫图标可打开主菜单(图3-1),其主要功能描述请看表1。
|
图3-1
|
菜单选项
|
说明
|
Disable Firebug |
关闭/开启Firebug对所有网页的编辑、调试和检测功能
|
Disable Firebug for xxxxx
|
关闭/开启Firebug对xxxxx网站的编辑、调试和检测功能
|
Allowed Sites
|
设置允许编辑、调试和检测的网站
|
Text Size:Increase text size
|
增大信息区域显示文本的字号
|
Text Size:Decrease text size
|
减少信息区域显示文本的字号
|
Text Size:Normal text size
|
信息区域以正常字体显示
|
Options:Always Open in New Window
|
设置Firebug控制窗口永远在新窗口打开
|
Show Preview tooltips
|
设置是否显示预览提示。
|
Shade Box Model
|
当前查看状态为HTML,鼠标在HTML element标签上移动时,页面会相应在当前标签显示位置显示一个边框表示该标签范围。这个选项的作用是设置是否用不同颜色背景表示标签范围。
|
Firebug Website..
|
打开Firebug主页。
|
Documentation..
|
打开Firebug文档页。
|
Discussion Group
|
打开Firebug讨论组。
|
Contribute
|
打开捐助Firebug 页面。
|
表1
|
4、 控制台(Console)
单击功能区第二栏的“Console”标签可切换到控制台(图4-1)。控制台的作用是显示各种错误信息(可在Options里定义),显示脚本代码中内嵌的控制台调试信息,通过命令行对脚本进行调试,通过单击Profile对脚本进行性能测试。 控制台分两个区域,一个是信息区,一个是命令行,通过Options菜单的“Larger Command Line”可改变命令行位置。
|
图4-1
|
Options菜单的选项请看表2。
菜单选项
|
说明
|
Show JavaScript Errors |
显示脚本错误。 |
Show JavaScript Warnings
|
显示脚本警告。
|
Show CSS Errors
|
显示CSS错误。
|
Show XML Errors
|
显示XML错误。
|
Show XMLHttpRequests
|
显示XMLHttpRequests。
|
Larger Command Line
|
将命令行显示从控制窗口底部移动右边,扩大输入区域。
|
表2
|
单击“Clear”按钮可清除控制台的控制信息。
5、 页面源代码查看功能
单击功能区第二栏的“HTML”标签可切换到源代码查看功能(图5-1)。虽然Firefox也提供了查看页面源代码的功能,但它显示的只是页面文件本身的源代码,通过脚本输出的HTML源码是看不到。而Firebug则是所见即所得,是最终的源代码。
|
图5-1
|
我们来看一个例子,文件源代码如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<title>简单的例子</title>
<meta http-equiv="content-type" content="text/html; charset=utf-8">
<style>
#div1{background:red;width:100px;height:100px;}
#div2{background:blue;width:100px;height:100px;margin:10px;padding:10px;border:5px solid black;color:white;}
#div3{background:yellow;width:50px;height:50px;margin-left:25px;}
</style>
</head>
<body scroll="no">
<div id="div1">方块一</div>
<div id="div2">方块二</div>
<script>
document.getElementById('div1').innerHTML+='<div id="div3">方块三</div>';
</script>
</body>
</html>
|
在例子中我们通过JavaScript在“div1”中加入了“div3”,在Firefox中查看源代码你是看不到“div1”中包含有代码“<div id="div3">
方块三</div>
”的,但是Firebug中我们是可以看见的(图5-2选中部分)。
|
图5-2
|
从图5-1中我们可以看到,信息区被分成了两个部分,左边是显示源代码,右边是一个功能区,可以从这里查看到HTML Element中的CSS定义、布局情况和DOM结构。
从图5-2中我们可以看到,源代码按DOM结构分层次显示的,通过层次折叠功能,我们就可以很方便分析代码。在功能区的第一行还根据你的选择,清晰的按子、父、根列出了当前源代码的层次(图5-2红色部分),单击各部分,则会即刻转到该部分的源代码。
|
图5-3
|
在源代码上移动鼠标,页面就会出现一个半透明的方块,指示当前鼠标所指源代码的显示区域,当选择。在图5-4中,鼠标正指向“div1”,而在页面中“div1”的显示区域上被一个半透明的方块遮盖了。
|
图5-4
|
如果你把“Inspect”按钮按下,功能正好相反,在页面中移动鼠标,则当前显示区域的源代码会被加亮显示出来。在图5-5中,我们可以看到鼠标指针正指向“方块二”,而在源代码中可以看到,“方块二”的源代码“<div id="div2">
方块二</div>
”已被加亮显示(红色部分)。如果你单击某个显示区域,则该区域的源代码会被选中。
|
图5-5
|
是不是很方便?方便是方便,但是我的源代码很多,而且有些区域在页面中不方便鼠标指定,怎么办?没关系,我们还有一个厉害武器,搜索功能。譬如我们知道某个HTML Element的ID是“div2”,但在层层叠叠的源代码中不好找,在页面中鼠标也很难找到,那我们就在功能区的搜索框中输入“div2”,再看看源代码区域,“div2”被加亮显示出来了(图5-6红色部分)。在这个简单的例子可能看不出很好的效果,大家可以尝试一下把“div1”先折叠起来,然后在搜索框输入“div3”,你可以看到“div1”会自动展开,并将“div3”加亮显示,如果还觉得不够理想,可以找一个源代码比较多的例子测试一下。
|
图5-6
|
除了通过按下“Inspect”按钮,单击显示区域选择源代码,我们还可以通过单击源代码中的HTML标记(开始或结束标记都可以)来选择。我们尝试一下把鼠标移动到HTML标记,会发现鼠标指针变成了手的形状,这说明我们可以通过单击选择该源代码。选择源代码后,我们就可以通过右边的功能区查看、编辑和调试它的CSS定义和盒子模型(CSS盒子模型请参阅相关说明,这里就不再赘述了),还有一个很好的功能就是当外部编辑器修改了源代码(没有删除该源代码,只是修改),我们在浏览器重新加载页面后,选择的源代码不会改变,我们可以很方便的观察源代码的变化与效果。
有没有经常为调试某个页面效果在源代码编辑器和浏览器之间切换,一次又一次的刷新而感到懊恼?有了Firebug你就不用再懊恼了。你可以直接在源代码中进行编辑,然后查看效果。如果只是修改已经存在的属性,例如要修改“div2”的内部文本,则直接将鼠标移动到文本上面,等鼠标指针换成“I”,单击即可进行编辑了。其它已存在的属性和属性值也可以这样直接进行编辑。如果要为某Element添加属性,请将鼠标移动到该Element上,等光标变为“I”的时候,单击鼠标右键,从菜单中选择“New Attribute..”,在显示的编辑框中输入你要添加的属性名称就可以了。
我们尝试一下为“div2”增加一个“onclick”属性,单击的结果是将“div2”的显示文本修改为“单击”。把光标移动到“div2”上,然后单击鼠标右键,选择“New Attribute..”(图5-7),在编辑框中输入“onclick”,最后按一下回车键(图5-8),出现属性值输入框后,输入“this.innerHTML=’单击’”,回车后我们可以继续添加下一个属性,这次测试不需要,所以按ESC结束我们的输入。我们来检验一下修改结果,单击页面“div2”的区域(图5-9),“div2”的显示文本已修改为“单击”了,而源代码也改变了。有没有发现,“div2”被加亮显示了?这又是Firebug的一个功能。只要我们通过页面中的操作修改了Element的属性,Firebug就会在源代码中通过加亮的方式指示当前操作修改那些属性值。譬如我们单击某个链接修改了一个iframe里的src,那么这个src的属性值就会被加亮显示。 又譬如我们单击某个链接修改了一个image里的图像,那么它的src属性值也会被加亮显示。我们可以通过Options菜单里的“Highlight Changes”设置是否加亮显示改变。而“Expand Changes”则是设置被改变的源代码折叠起来看不见时展开让它可见。而“Scroll Changes into view”则是源代码很多,被改变的源代码不在可视区域时,将被改变的源代码滚动到可视区域。
有时候我们不单是要增加一两个属性,而是要做更多的修改,这怎么办呢?很简单,选择你要更改Element,然后单击功能区第一行的“Edit”按钮或者直接将鼠标移动到要修改的Element上,单击鼠标右键,选择“Edit HTML..”,这时候,源代码区域将切换到编辑状态,你可以随意的修改你选择的源代码了。我们尝试修改一下“div2”,将被修改显示文本修改回“方块二”,我们选择“div2”,然后单击“Edit”按钮(图5-10),将显示文本修改回“方块二”,然后再次单击“Edit”按钮退出编辑状态,如果要放弃修改,可以按ESC键退出。因为是所见即所得的,所以我们在修改的时候,页面会同时刷新显示。
如果要修改Element的CSS定义怎么办?很简单,选择该Element,然后在右边的窗口选择“Style”标签,这里显示的就是当前Element的CSS定义了。我们在这里可以对CSS定义进行添加、编辑、删除、禁止等操作。我们尝试一下把“div2”的背景色禁止了看看。将鼠标移动到“background”这行(图5-11),我们可以看到在这行的最右边会有一个灰色的禁止图标,只要单击这个禁止图标,就可以禁止了这个CSS属性了。我们单击这个图标看看效果,页面中的“div2”已经变成白色背景了,而禁止图标也变成红色,而文本会则变成灰色(图5-12),这说明已经禁止了“background”了。当然了,这个操作也可以通过鼠标右键的“Disable XXXXX”来实现(XXXXX表示当前选择的CSS属性)。我们再次单击禁止图标,恢复“background”属性。我们这次要把“background”的颜色由蓝色(blue)修改为绿色(green)。我们把鼠标移动到“background”属性值“blue”上(图5-13)。怎么会出现一个蓝色背景的方框?这是Firebug提供背景预览功能,让我们很直观的知道当前背景是什么。如果背景是图片的话,显示的将是背景图片的缩略图。继续我们的操作,单击属性值,在出现的编辑框中将“blue”修改为“green”。好了,背景已经修改为绿色了。现在的显示文本是左对齐的,我想让它居中对齐,这需要在CSS里加一个“text-align”的属性,值为“center”。请在CSS上单击鼠标右键,在菜单中选择“New Property..”,在编辑框中输入“te”,Firebug已通过自动完成功能帮我们输入“text-align”了(图5-14),按Tab键或回车,在属性值中我们输入“c”,Firebug再次帮我们自动完成了“center”(图5-15),按Tab键或回车完成输入,如果不需要继续输入新属性,按ESC或单击鼠标取消输入。文本“方块二”现在已经居中显示了。如果忘记了某个属性值有那些选项怎么办?不要紧,在输入属性值的时候可以通过上、下箭头选择我们需要的属性值。
在“Style”标签里我们可以选择“Options”菜单里的“Show Computed Style”查看浏览器默认的风格定义。
页面设计中,我们有时候最头疼的是什么?是盒子模型!为了调整一个Element的margin、border、padding和相对位置,我们往往需要花很多工夫去修改源代码,然后刷新页面查看效果。有了Firebug,你就可以轻松应对了。我们将右边的区域切换到“Layout”标签(图5-16),你会看到一个盒子模型,里面从外到里通过不同的线和颜色划分出了offset、margin、border、padding和内容五个区域,里面4个区域在每个边上都有1个数值,表示该方向上的调整值。我们先在左边选择“div2”,然后把鼠标分别移动到“Layout”里的不同区域(图5-17),然后留意一下页面,页面在顶部多了一条水平标尺,在左边多一条垂直标尺,而4条实线指示出了当前鼠标指示的区域实际位置,通过与标尺的交点可以知道该区域离页面显示区域左上角的偏移量(单位是px),当然我们也可以通过layout中的数字计算出这些偏移量。在图中,我们还可以看到,在内容区域的外面还有3个不同颜色的区域,它们从里到外用不同颜色表示了padding、border、margin的位置和偏移量。只要将鼠标移动到不同区域,页面中的4条实线也会改变位置,指示出页面中相应的区域。我们还可以通过修改Layout中的数值,对显示效果进行调整。例如我们要将“div2”的内容显示区域扩大到200×200,将鼠标移动最左边的100上,光标变成“I”后,单击鼠标,然后在输入框中输入200</spa
分享到:
相关推荐
Javascript的调试利器:Firebug使用详解
总结,Firebug作为JavaScript的调试利器,通过其强大的调试、检查和分析功能,极大地提升了开发效率和代码质量。虽然现在有更多现代的开发者工具,如Chrome DevTools和Firefox Developer Tools,但了解并掌握Firebug...
Javascript的调试利器:Firebug使用详解 分类: JavaScript2007-09-02 13:2086686人阅读评论(75)收藏举报 Javascript的调试,是开发Web应用尤其是AJAX应用很重要的一环,目前对Javascript进行调试的工具很多,我...
在JavaScript开发中,调试是必不可少的一个环节,而Firebug作为一款强大的JavaScript调试工具,提供了丰富的功能来帮助开发者定位和解决问题。本文将详细介绍如何使用Firebug中的`console`对象进行调试,以及一些...
Firebug是一款强大的Web开发工具,尤其对于JavaScript的调试而言,它是不可或缺的利器。这款插件在Firefox浏览器上运行,提供了对HTML、CSS、JavaScript、网络请求等多方面的实时查看和编辑功能,极大地提升了开发者...
Firebug的功能包括HTML、CSS、JavaScript的实时编辑和调试,以及对网络请求的监控,是前端开发人员不可或缺的利器。 一、火狐浏览器的特性与优势 1. 开源:火狐浏览器基于开放源代码的Gecko引擎,允许开发者深入...
### Firebug使用详解 在Web开发领域,尤其是针对复杂度较高的AJAX应用,JavaScript的调试是不可或缺的一环。Firebug,由Joe Hewitt开发,是一款与Firefox无缝集成的强大Web开发工具,它支持实时编辑、调试以及监测...
3. JavaScript调试:Firebug的JavaScript控制台提供了断点设置、单步执行、变量查看等功能,使得代码调试变得简单易行。开发者可以清晰地追踪代码执行过程,找出逻辑错误或性能瓶颈。 4. 网络监控:Firebug能够记录...
6. **性能分析**:使用Timeline面板,开发者可以分析页面的渲染性能,包括JavaScript执行、重绘和回流等过程,帮助优化页面性能。 7. **命令行工具**:Firebug的命令行提供了一系列便捷的命令,如查找DOM元素、执行...
**火狐浏览器的Firebug插件详解** 火狐(Firefox)作为一款开源的网络浏览器,以其高度可定制性和安全性受到广大用户的喜爱。在网页开发领域,火狐的Firebug插件是一个不可或缺的工具,它为开发者提供了强大的网页...
FireBug是Web开发者的一款利器,尤其在JavaScript、HTML和CSS的调试方面表现卓越。虽然原版FireBug是为Firefox浏览器设计的,但通过"FireBug Lite",用户也可以在Internet Explorer(IE)中享受到类似的调试功能。...
- **JavaScript调试**:Firebug允许开发者设置断点,查看变量值,跟踪代码执行流程,是解决JavaScript错误的利器。 - **DOM显示**:它能展示动态更新后的DOM树结构,包括动态添加或删除的元素,这对于理解Ajax请求后...
《火狐调试神器:fire_debug1.62详解》 在Web开发的世界里,调试工具是开发者不可或缺的利器。火狐浏览器(Firefox)作为一个开放源代码的浏览器,为开发者提供了丰富的扩展工具,其中“fire_debug1.62”是专为火狐...
"IEjs开发调试工具IEDevToolBarSetup"就是这样一个针对IE浏览器的利器,它提供了丰富的功能,旨在提高开发和调试JavaScript代码的效率。 首先,我们来了解一下什么是IEDevToolBar。这是一款专为IE设计的开发者工具...
这对于网页开发者来说,无疑是一个提升工作效率和解决问题的利器,尤其是对于JavaScript的调试,Firebug提供了直观的界面和详细的错误报告,使得调试工作变得轻松而高效。 在实际使用过程中,用户只需在Firefox中...
分别介绍了JavaScript的对象编程、JavaScript浏览器对象模型和事件机制、ExtJS的核心类库和组件、ExtJS的事件处理方式、设计进度条、设计工具栏和菜单栏、设计面板、设计表格、设计表单、设计数据表、对Ajax的支持...
分别介绍了JavaScript的对象编程、JavaScript浏览器对象模型和事件机制、ExtJS的核心类库和组件、ExtJS的事件处理方式、设计进度条、设计工具栏和菜单栏、设计面板、设计表格、设计表单、设计数据表、对Ajax的支持...