Javascript 调试利器 Firebug使用详解六


Posted in Javascript onJuly 05, 2009

我们测试一下把刚才的4个输出作为一个分组输出,修改代码为:

console.group('开始分组:'); 
console.debug('This is console.debug!'); 
console.info('This is console.info!'); 
console.warn('This is console.warn!'); 
console.error('This is console.error!'); 
console.groupEnd();

刷新页面看看结果(图11-5)。在console.group中,我们还可以加入一个组标题“开始分组:”。如果需要,我们还可以通过嵌套的方式,在组内再分组。
Javascript 调试利器 Firebug使用详解六
图11-5
有时候,我们需要写一个for循环列出一个对象的所有属性或者某个HTML Element下的所有节点,有了firebug后,我们不需要再写这个for循环了,我们只需要使用console.dir(object)或console.dirxml(element)就可以了。
在测试页中加入代码测试一下:
console.dir(document.getElementById('div1')); 
console.dirxml(document.getElementById('div1'));

结果请看图11-6和图11-7。
Javascript 调试利器 Firebug使用详解六 
图11-6
Javascript 调试利器 Firebug使用详解六
图11-7
是否想知道代码的运行速度?很简单,使用console.time和console.timeEnd就可以。
修改一下test函数的代码,测试一下运行1000次循环需要多少时间:
function test(){ 
console.time('test'); 
for(var i=0;i<1000;i++){ 
document.getElementById('div2').innerHTML=i; 
//console.log('当前的参数是:%d',i); 
} 
console.timeEnd('test'); 
}

刷新页面,单击“方块二”,看看结果(图11-8)。在这里要注意的是console.time和console.timeEnd里的参数要一致才会有正确的输出,而该参数就是信息的标题。
Javascript 调试利器 Firebug使用详解六
图11-8
是否想知道某个函数是从哪里调用的?console..trace可帮助我们进行追踪。在test函数的结尾加入:
console.trace();
刷新页面,单击“方块二”,看看结果(图11-9)。结果显示是在坐标(97,187)的鼠标单击事件执行了test函数,而调用的脚本是在simple.html文件里的第1行。因为是在HTML里面的事件调用了test函数,所以显示的行号是第1行。如果是脚本,则会显示调用脚本的行号,通过单击可以直接去到调用行。
Javascript 调试利器 Firebug使用详解六
图11-9
如果想在脚本某个位置设置断点,可以在脚本中输入“debugger”作为一行。当脚本执行到这一行时会停止执行等待用户操作,这时候可以通过切换到“Script”标签对脚本进行调试。
Firebug还有其它的一些调试函数,这里就不一一做介绍,有兴趣可以自己测试。表4是所有函数的列表:
函数 说明
console.log(object[, object, ...]) 向控制台输出一个信息。可以输入多个参数,输出将已空格分隔各参数输出。 第一参数可以包含格式化文本,例如: console.log(‘这里有%d个%s',count,apple); 字符串格式: %s :字符串。 %d, %i:数字。 %f: 浮点数。 %o -超链接对象。
console.debug(object[, object, ...]) 向控制台输出一个信息,信息包含一个超链接链接到输出位置。
console.info(object[, object, ...]) 向控制台输出一个带信息图标和背景颜色的信息,信息包含一个超链接链接到输出位置。
console.warn(object[, object, ...]) 向控制台输出一个带警告图标和背景颜色的信息,信息包含一个超链接链接到输出位置。
console.error(object[, object, ...]) 向控制台输出一个带错误图标和背景颜色的信息,信息包含一个超链接链接到输出位置。
console.assert(expression[, object, ...]) 测试一个表示是否为true,如果为false,提交一个例外信息到控制台。
console.dir(object) 列出对象的所有属性。
console.dirxml(node) 列出HTML或XML Element的XML源树。
console.trace() 输出堆栈的调用入口。
console.group(object[, object, ...]) 将信息分组再输出到控制台。通过console.groupEnd()结束分组。
console.groupEnd() 结束分组输出。
console.time(name) 创建一个名称为name的计时器,计算代码的执行时间,调用console.timeEnd(name)停止计时器并输出执行时间。
console.timeEnd(name) 停止名称为name的计时器并输出执行时间。
console.profile([title]) 开始对脚本进行性能测试,title为测试标题。
console.profileEnd() 结束性能测试。
console.count([title]) 计算代码的执行次数。titile作为输出标题。
表4

12、 在IE中使用Firebug
Firebug是Firefox的一个扩展,但是我习惯在IE中调试我的页面怎么办?如果在页面脚本中加入console.log()将调试信息写到Friebug,在IE中肯定是提示错误的,怎么办?不用担心,Frirebug提供了Frirbug Lite脚本,可以插入页面中模仿Firebug控制台。
我们可以从一下地址下载firebug lite:
http://www.getfirebug.com/releases/firebuglite1.0-b1.zip
然后在页面中加入:
<script language="javascript" type="text/javascript" src="/路径/firebug.js"></script>
如果你不想在IE中模仿Friebug控制台,只是不希望console.log()脚本出现错误信息,那么在页面中加入一下语句:
<script language="javascript" type="text/javascript" src="/路径/firebugx.js"></script>
如果你不想安装Firebug Lite,只是想避免脚本错误,那么可以在脚本中加入以下语句:
if (!window.console || !console.firebug)
{
var names = ["log", "debug", "info", "warn", "error", "assert", "dir", "dirxml",
"group", "groupEnd", "time", "timeEnd", "count", "trace", "profile", "profileEnd"];
window.console = {};
for (var i = 0; i < names.length; ++i)
window.console[names[i]] = function() {}
}
我们将firebug.js加入到测试页面中,然后打开IE,加载页面。页面加载完成后,我们按下F12键就可以打开控制台了。每次页面刷新后,你都要按F12键打开控制台,是不是很烦?如果不想那么,就在html标签中加入“debug='true'”,例如:
<html debug="true">
在Friebug Lite中也有命令行,但是功能没那么强。
Javascript 相关文章推荐
HTA版JSMin(省略修饰语若干)基于javascript语言编写
Dec 24 Javascript
JavaScript把数组作为堆栈使用的方法
Mar 20 Javascript
jQuery实现二级下拉菜单效果
Jan 05 Javascript
基于JQuery的$.ajax方法进行异步请求导致页面闪烁的解决办法
May 10 Javascript
JavaScript直播评论发弹幕切图功能点集合效果代码
Jun 26 Javascript
js数组去重的hash方法
Dec 22 Javascript
js实现淡入淡出轮播切换功能
Jan 13 Javascript
详解JS获取HTML DOM元素的8种方法
Jun 17 Javascript
详解vue2.0+vue-video-player实现hls播放全过程
Mar 02 Javascript
javascript中函数的写法实例代码详解
Oct 28 Javascript
vue实现页面切换滑动效果
Jun 29 Javascript
Vue中keep-alive组件的深入理解
Aug 23 Javascript
jQuery DIV弹出效果实现代码
Jul 03 #Javascript
Javascript 遍历对象中的子对象
Jul 03 #Javascript
javascript web页面刷新的方法收集
Jul 02 #Javascript
javascript 操作文件 实现方法小结
Jul 02 #Javascript
javascript new 需不需要继续使用
Jul 02 #Javascript
ExtJS GTGrid 简单用户管理
Jul 01 #Javascript
JQuery 风格的HTML文本转义
Jul 01 #Javascript
You might like
递归列出所有文件和目录
2006/10/09 PHP
用来解析.htpasswd文件的PHP类
2012/09/05 PHP
windows下配置apache+php+mysql时出现问题的处理方法
2014/06/20 PHP
PHP一个简单的无需刷新爬虫
2019/01/05 PHP
In Javascript Class, how to call the prototype method.(three method)
2007/01/09 Javascript
Tips 带三角可关闭的文字提示
2010/10/06 Javascript
jQuery filter函数使用方法
2014/05/19 Javascript
JQuery弹出炫丽对话框的同时让背景变灰色
2014/05/22 Javascript
js+jquery实现图片裁剪功能
2015/01/02 Javascript
浅析javascript中的DOM
2015/03/01 Javascript
js兼容火狐获取图片宽和高的方法
2015/05/21 Javascript
JS正则表达式比较常见用法
2016/01/26 Javascript
react.js CMS 删除功能的实现方法
2017/04/17 Javascript
微信小程序之购物车功能
2020/09/23 Javascript
JavaScript数组排序reverse()和sort()方法详解
2017/12/24 Javascript
微信小程序图片轮播组件gallery slider使用方法详解
2018/01/31 Javascript
[01:24:16]2018DOTA2亚洲邀请赛 4.6 全明星赛
2018/04/10 DOTA
Python中的文件和目录操作实现代码
2011/03/13 Python
Python类属性与实例属性用法分析
2015/05/09 Python
Python 中urls.py:URL dispatcher(路由配置文件)详解
2017/03/24 Python
初学python的操作难点总结(新手必看篇)
2017/08/03 Python
Python实现FM算法解析
2019/06/18 Python
python文件选择对话框的操作方法
2019/06/27 Python
PyTorch之图像和Tensor填充的实例
2019/08/18 Python
对python while循环和双重循环的实例详解
2019/08/23 Python
哈工大自然语言处理工具箱之ltp在windows10下的安装使用教程
2020/05/07 Python
python基于pexpect库自动获取日志信息
2021/02/01 Python
Ray-Ban雷朋瑞典官方网站:全球领先的太阳眼镜品牌
2019/08/22 全球购物
大学毕业生工作的自我评价
2013/10/01 职场文书
硕士研究生自我鉴定
2013/11/08 职场文书
工程质量承诺书
2014/03/27 职场文书
2016关于预防职务犯罪的心得体会
2016/01/21 职场文书
某某幼儿园的教育教学管理调研分析报告
2019/11/29 职场文书
MySQL sql_mode的使用详解
2021/05/08 MySQL
教你使用VS Code的MySQL扩展管理数据库的方法
2022/01/22 MySQL
Spring Boot DevTools 全局配置学习指南
2022/03/31 Java/Android