如何调试JS?

JavaScript022

如何调试JS?,第1张

不雷同,firebug

确实强大。不过IE的怎么会不好用了?

IE8

的js调试功能我觉得挺好用的,F12进入,选择脚本栏,打断点,然后启动调试

F10

单步跳过、F11单步进入,F5等等,右侧还可监测变量

如何在ietester下使用firebug

首先,需要说明的是,此firebug并不是firefox下的插件firebug。众所周知,firebug是firefox下的调试利器,但在ie下没有相关的插件,为了在ie下实现firebug功能,所以出了这么一个组件,它是完全用js生成的仿firebug界面。功能当然没有真正的firebug强大,但其操作和firebug很像,界面也像,对于习惯firebug的工程师来说,使用它非常亲切。其官方网站是http://uicss.cn/r.php?hr=http://getfirebug.com/lite.html

有一点很让人郁闷的是,官方提供的加载它的方法是给html加载一个<script>标签,引用这段js到页面里去。这个在开发阶段当然是没有问题,但如果是调试已经在线上的页面,比如http://www.sina.com.cn,怎么办呢?有办法能像firefox下的firebug一样随时可以调用吗?

有,一个最简单的办法就是使用油猴。IE下的油猴见:http://www.bhelpuri.net/Trixie/

如果是使用maxthon的话,maxthon也有自己的油猴插件,叫做more scripts,见:http://addons.maxthon.cn/zh_CN/search/all/bW9yZSBzY3JpcHRz

但问题是我们经常需要在ie6,ie7,ie8三个不同版本的ie下进行调试,如果是其中一个版本出现了问题呢?当然,ie6,ie7和ie8的js引擎没啥大区别,主要是指css方面的问题。我们如何调试呢?为了调试ie6,ie7和ie8,我们最常用的软件是ietester,而ietester本身其实也带调试工具DebugBar。用DEbugBar比起ie自带的developer

toolbar最大的好处是它可以运行在不同的内核之上,ie6,7,8都可以进行调试。但DebugBar真的是超级难用!!如果能将ietester的多ie内核功能,结合firebug的易用性,该多好啊!可是ietester下没有油猴。。。

还是有办法的,现在就告诉你我的办法。首先打开ietester的DebugBar,切换到脚本标签,可以看到最下面一栏有个输入框,注释写着"//

Javascript 控制台",这是个类似于firebug的脚本控制台的功能,可以输入js并运行。

我们在这里输入脚本:

=============================================

var s = document.createElement("script")

s.src =

'http://getfirebug.com/releases/lite/1.2/firebug-lite-compressed.js'

s.type="text/javascript"

if(document.all){

s.onreadystatechange = function(){

if(this.readyState == "loaded" ||

this.readyState == "complete"){

alert("loaded success in ie")

}

}

} else {

s.onload = function(){

alert("load

success")

}

}

document.body.appendChild(s)

================================================

这里的思路是动态创建一个script标签,然后监听它的onload事件,当它加载完成时,会alert一下加载成功信息。运行脚本,等到弹出"loaded

success in

ie"后,表示我们的firebug组件的脚本已经加载进来了。但此时,firebug的界面并没有出现!别着急,我们将输入框中的代码清除掉,再输入如下代码:

==================

firebug.init()

==================

运行它,过一会儿,就会看到firebug的界面出现了!我用这个方法成功在htttp://www.sina.com.cn调出了firebug,如截图所示:

ok,ietester下我们已经可以使用firebug了。接下来,我们看看不同版本ie内核下的firebug能不能按我们预期的那样,在不同内核下真实显示当前的信息。

写了个小demo,如下:

=======================================

<!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/htmlcharset=utf-8" />

</head>

<body>

<style

type="text/css">

#test{padding:20pxbackground:green*background:blue_background:yellow}

</style>

<div

id="test">hello world</div>

</body>

</html>

=======================================

定义了一个id为test的div,用css

hack让它在ie6,7,8下背景色分别为yellow,blue,green。然后,看看在不同内核版本下firebug会如何显示当前的样式信息呢?

哈哈,很顺利。大功告成 ^0^。

1.在 IE10 中按下 Alt 键打开菜单栏,单击“工具-兼容性视图设置”,弹出兼容性视图设置对话框。

2.在对话框中,勾选“在兼容性视图中显示所有网站”,然后点击“关闭”。

3.然后按下 F12 ,弹出一个对话框,点击菜单中的“IE10兼容性视图”,选择Internet Explorer 8,浏览器自动切换为IE8模式了。

4.其实在360浏览器中,这个工作则要简单很多,在地址栏右侧有个内核切换按钮,点击切换可以切换了IE兼容模式。