7种JavaScript代码调试的方法

7种JavaScript代码调试的方法


JS是解释型语言,是逐条语句解释执行的,如果错误发生在某个语句块,此语句块以前的语句一般都可以正常执行。这不同于C等编译型语言。
JS是解释型语言,是逐条语句解释执行的,如果错误发生在某个语句块,此语句块以前的语句一般都可以正常执行。这不同于C等编译型语言。
代码调试的重点在于找到错误发生点,然后才能有的放矢。

1.alert()

通常可以使用警告框来提示变量信息。

alert(document.body.innerHTML); 

当警告框弹出时,用户将需要单击“确定”来继续。

2.html标签内使用document.write()

<div id="demo"> </div>    
<script>        
var arr=[1,2,3,4,5]       
document.write(arr[2] + ' ') //3    
</script>

需要注意的是是,以下写法会替换整个页面的内容:

<button type="button" onclick="document.write(5 + 6)">试一试</button> 

即使是函数调用也是如此。

3.innerHTML()

document.getElementById(“demo”).innerHTML =""

<h1>JavaScript Array.filter()</h1>
<p>使用通过测试的所有数组元素创建一个新数组。</p>
<p id="demo"></p>
 <script>   
 	var numbers = [45, 4, 9, 16, 25];    
 	var over18 = numbers.filter(myFunction);    
 	document.getElementById("demo").innerHTML = over18;    
 	function myFunction(value, index, array) {
 	        return value > 18;
 	}
 </script> 

4.console()

JS的运行环境是浏览器,由浏览器引擎解释执行JS代码,一般来说,浏览器也提供调试器,如chrome按F12即可调出高试器:

<!DOCTYPE html>
<html>
	<body>
		<h4>我的第一张网页</h4>
		<p>使用F12在浏览器(Chrome、IE、Firefox)中激活调试,然后在调试器菜单中选择“控制台”。</p> 
	<script>        
		a = 5;        
		b = 6;        
		c = a + b;        
		console.log(c);    
	</script>
	</body>
</html> 

如果您的浏览器支持调试,那么您可以使用 console.log() 在调试窗口中显示 JavaScript 的值:
JS|7种JavaScript代码调试的方法
内置的调试器可打开或关闭,强制将错误报告给用户。
通过调试器,您也可以设置断点(代码执行被中断的位置),并在代码执行时检查变量。

5.try catch捕获错误

<p id="demo"></p>
<script>
	try {  
		adddlert("欢迎您,亲爱的用户!");
	}catch(err) { 
		demo.innerHTML = err.message; //adddlert is not defined
	}
</script> 

JavaScript 实际上会创建带有两个属性的 Error 对象:name 和 message。
name 设置或返回错误名。
message 设置或返回错误消息(一条字符串)。

6.debugger

debugger停止执行 JavaScript,并调用调试函数(如果可用)。

7.注释法或增量法

可以注释掉一些可疑代码来确定错误发生点。
或者考虑逐步增加代码的方法,逐步验证,以避免错误。

8.一些常见的 JavaScript 错误。

8.1 意外使用赋值运算符

如果程序员在 if 语句中意外使用赋值运算符(=)而不是比较运算符(===),JavaScript 程序可能会产生一些无法预料的结果。

8.2 令人困惑的加法和级联

加法用于加数值。
级联(Concatenation)用于加字符串。
在 JavaScript 中,这两种运算均使用相同的 + 运算符。
正因如此,将数字作为数值相加,与将数字作为字符串相加,将产生不同的结果:

var x = 10 + 5;          // x 中的结果是 15var x = 10 + "5";         // x 中的结果是 "105" 

而加法以外的其它算法运算符可以将字符串进行自动类型转换。
10-“5” // 5

8.3 令人误解的浮点数

JavaScript 中的数字均保存为 64 位的浮点数(Floats),符合IEEE754的标准。
所有编程语言,包括 JavaScript,都存在处理浮点值的困难:

var x = 0.1;var y = 0.2;var z = x + y             // z=0.30000000000000004 
8.4 错位的分号

因为一个错误的分号,此代码块无论 x 的值如何都会执行:

if (x == 19);{     // code block} 

在一行的结尾自动关闭语句是默认的 JavaScript 行为。
在 JavaScript 中,用分号来关闭(结束)语句是可选的。

8.5 对象使用命名索引

在 JavaScript 中,数组使用数字索引。
在 JavaScript 中,对象使用命名索引。
如果您使用命名索引,那么在访问数组时,JavaScript 会将数组重新定义为标准对象。

<p id="demo"></p>
<script>
	var person = [];
	person["firstName"] = "Bill";
	person["lastName"] = "Gates";
	person["age"] = 46;
	var x = person.length; // person.length 将返回 0 
	var y = person[0];// person[0] 将返回 undefined
	y=person["age"]; //ok
	y=person.age;//ok
	document.getElementById("demo").innerHTML = y
</script>
8.6 Undefined 不是 Null

Undefined 的类型是 Undefined,Null的类型是Object。
JavaScript 对象、变量、属性和方法可以是未定义的。
此外,空的 JavaScript 对象的值可以为 null。
在测试非 null 之前,必须先测试未定义:

if (typeof myObj !== "undefined" && myObj !== null)
8.7 JS没有块作用域(与C语言不同)

在 ES2015 之前,JavaScript 只有两种类型的作用域:全局作用域和函数作用域。

<!DOCTYPE html>
    <html>
    <body>
        <h2>JavaScript</h2>
        <p>
            JavaScript不会为每个代码块创建新的作用域。
        </p>
        <p>此代码将显示 i(10)的值,即使在 for 循环块之外:</p>
        <p id="demo"></p>
        <script>
        	for (var i = 0; i < 10; i++) {  // some
        		 code
        	}
        	document.getElementById("demo").innerHTML = i; //10
        </script>
    </body>
    </html>

ES2015 引入了两个重要的 JavaScript 新关键词:let 和 const。
这两个关键字在 JavaScript 中提供了块作用域(Block Scope)变量(和常量)。

for (let i = 0; i < 10; i++) {  // some 
	code
}
document.getElementById("demo").innerHTML = i; //不能访问 

在这里插入图片描述

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

X W F

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值