JavaScript有哪些代码调试的方法

本篇内容介绍了“JavaScript有哪些代码调试的方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

  JS是解释型语言,是逐条语句解释执行的,如果错误发生在某个语句块,此语句块以前的语句一般都可以正常执行。这不同于C等编译型语言。

  代码调试的重点在于找到错误发生点,然后才能有的放矢。

  1.alert()

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

  alert(document.body.innerHTML);

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

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

  < div id="demo"> < script> var arr=[1,2,3,4,5]

  document.write(arr[2] + ' ') //3 < /script>< /div>

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

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

  3.innerHTML()

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

  JavaScript Array.filter()

  使用通过测试的所有数组元素创建一个新数组。

  //45,25

  4.console()

  JS的运行环境是浏览器,由浏览器引擎解释执行JS代码,一般来说,浏览器也提供调试器,如chrome按F12即可调出高试器。使用F12在浏览器(Chrome、IE、Firefox)中激活调试,然后在调试器菜单中选择“控制台”。

  如果您的浏览器支持调试,那么您可以使用 console.log() 在调试窗口中显示 JavaScript 的值:

  内置的调试器可打开或关闭,强制将错误报告给用户。

  通过调试器,您也可以设置断点(代码执行被中断的位置),并在代码执行时检查变量。

  5.try catch捕获错误

  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 会将数组重新定义为标准对象。

  8.6 Undefined 不是 Null

  Undefined 的类型是 Undefined,Null的类型是Object。

  JavaScript 对象、变量、属性和方法可以是未定义的。

  此外,空的 JavaScript 对象的值可以为 null。

  在测试非 null 之前,必须先测试未定义:

  if (typeof myObj !== "undefined" && myObj !== null)

  8.7 JS没有块作用域(与C语言不同)

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

  JavaScript

  JavaScript不会为每个代码块创建新的作用域。

  此代码将显示 i(10)的值,即使在 for 循环块之外:

  ES2015 引入了两个重要的 JavaScript 新关键词:let 和 const。

  这两个关键字在 JavaScript 中提供了块作用域(Block Scope)变量(和常量)。

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

“JavaScript有哪些代码调试的方法”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!