Web调试入门

调试本身可分为两个过程:定位问题解决问题

本课程将集中讨论如何快速发现定位问题,解决问题本身就是开发的基本功,具体办法涉及框架,这里不深入探讨。我们将从以下几点开始:

  1. 掌握调试工具的基本使用
  2. 调试基本流程
  3. 通过案例定位Bug,修复Bug。

学完今天的内容:

  1. 掌握Chrome调试工具的基本使用
  2. 认识常见JS4种报错姿势
  3. 能够在报错中提取关键信息
  4. 能够通过调试工具、二分注释排除法,准确定位代码Bug位置。

Vue调试工具

Vue.js devtools 6.6.1 卡死崩溃,不要使用了 替换方案:Vue.js devtools - UI Customized,相当于Vue.js devtools6.5.1

Vue3 + vite 用这个 https://devtools-next.vuejs.org

Chrome调试工具

  1. 右击网页-选择"检查"
  2. 快捷键F12Fn + F12

修改停靠位置:

image-20230427230114981

调试工具的基本功能介绍

调试工具的面板有很多,先掌握做常用的4个

  • 元素(Element)
  • 控制台(Console)
  • 源代码(Sources)
  • 网络(Network)

元素 (Element)

**作用:**快速调试样式

**注意:**刷新会丢失

**实用小技巧:**🔔🔔

  1. 调试样式 上 下 方向键可以快速微调
  2. 存储为全局变量,快速获取dom元素
image-20230427231226206

控制台(Console)

**作用:**输出浏览器运行过程中产生的信息

image-20230427231940895

如何打印不同的颜色?

  console.error('这是一条红色的文字');
  console.log('这是一条黑色的文字');
  console.warn('这是一条黄色的文字');

如何打印一个DOM元素?

	const h1Node = document.querySelector('h1')

  // JS中万物皆对象
  // dir专门打印对象
  console.dir(h1Node)

	function hello() { }

	console.dir(hello)

源代码 (Source)

断点:代码会在断点处停住,给开发者观察的机会

需要掌握的操作按钮:

image-20230427233725584

上面有几个控制执行的按钮,分别是:

img 恢复执行

img 跳过下一个函数的执行过程

img 进入函数调用

img 跳出函数调用

image-20230427234049695单步执行

img 让断点失效

网络 (NetWork)

访问示例网站(http://geek.itheima.net/),观察请求信息:

浏览器发的请求信息展示

image-20230427235910929

image-20230428000510443

服务端响应的信息展示:

image-20230428000711819

image-20230428000827807

了解的HTTP状态码有哪些?

扩展:完整的状态码open in new window

成功(2XX)

状态码原因短语说明
200OK表示从客户端发来的请求,在服务器端被正确处理
201Created请求已经被实现,⽽且有⼀个新的资源已经依据请求的需要⽽建⽴
通常是在POST请求,或是某些PUT请求之后创建了内容, 进行的返回的响应
204No content表示请求成功,但响应报⽂不含实体的主体部分(后端不返回任何内容)

客户端错误(4XX)

状态码原因短语说明
400Bad Request请求报⽂存在语法错误((传参格式不正确) -
401UnAuthorized权限认证未通过(没有权限)
404Not Found表示在服务器上没有找到请求的资源
405Method Not Allowed请求的方法不对

服务端错误(5XX)

状态码原因短语说明
500Internal Sever Error表示服务器端在执⾏请求时发⽣了错误
503Service Unavailable表明服务器暂时处于超负载或正在停机维护,⽆法处理请求

调试基本流程

核心原则:精确定位bug位置,分析原因、解决问题。

整体流程:

  1. 有报错:查看控制台,定位是否为语法问题、类库兼容问题。
  2. 通信不成功:查看网络,定位前端问题,或是后端问题。
  3. 无报错,或报错且无有效信息-二分注释排查法

控制台报错:💥💥💥💥💥

程序报错是编程中,设计的辅助开发机制,报错是要把关键信息,给程序员查看。 因此,看见报错不要慌,看见英文不要慌。

掌握以下几个关键点,不会英文,也能吊打报错。 报错不可怕,可怕的是不报错。

报错可简单分两大类:

  1. JS常见错误
  2. 类库兼容问题

程序员问题,掌握报错查看技巧,快速解决。类库兼容问题,面向百度、GithubGoogle编程。


认识-JS常见错误

思考:是否留意过控制台报错,有几种类型?各自代表什么?

参考:来自1000个大型JS项目中的报错open in new window

常见错误有3~4类:

  1. SyntaxError(语法错误)

    image-20230426111546196

  2. ReferenceError (引用错误)

    image-20230426124659885

  3. TypeError (类型错误)

    image-20230426111217092

  4. RangeError (死循环)

    image-20230427115532887

小结:

  • 常见报错类型-4类
    • SyntaxError - 语法错误
    • ReferenceError - 引用错误,通常是变量或方法没有声明,直接使用
    • TypeError - 类型错误,通常是在错误的数据类型上,访问某个方法或属性
    • RangeError - 死循环
  • 报错中需要关注的三类信息
    • 报错信息:错误类型、提示文字
    • 报错文件
    • 报错行数

小技巧🔔:

  1. 从左向右、从上向下阅读报错
  2. 点击报错文件,Chrome调试工具,自动定位到报错位置

认识-类库兼容问题

目前前端工程化、模块化开发,一个项目中会使用到大量的第三方库,而不同的库升级速度之间存在差异,会导致前端出现大量的兼容报错。

  • 如何界定是第三方库的问题?
  • 如何解决此类问题?

如何确定是第三方库的问题?

报错信息中无源码文件提示,无常见错误提示。如下图

image-20230427122647228

如何解决此类问题?

  • 面向百度编程、面向Google编程。
  • 经验积累,看得多,了解的多。

前后端通信问题

目标:前后端分离开发方式普及,前后端先各自开发,再联调。因此,前端开发工程师,需要熟练使用NetWork面试调试。

如何确定前后端通信出现问题?

HTTP状态码:出现4XX、5XX

4XX:根据状态码和接口报错信息,修复代码。

5XX:提供调用数据,通知后台查看。

2XX:以预期数据与实际数据一致为准。

状态码4XX

目标:4XX大概率是前端调用API出现问题,需要熟练结合 ConsoleNetWork 面板处理。

出现4XX,结合状态码快速分析原因:

400:请求体传递参数不对。

  1. NetWork查看请求体
  2. 比对接口文档,
    1. 数据格式,是否一致。
    2. 属性名,是否一致。

401:token失效,请求头没有携带token。

  1. 查看请求头,是否有token
  2. 重新登录,验证token过期。

404:没有该接口(通常是url路径写的有问题)

  1. 查看请求头上的url路径
  2. 核对接口文档的url路径

405:请求方式不对(通常是get 、post、put等方式写错)

  1. 查看请求头中的method字段
  2. 核对接口文档的method字段

状态码5XX

目标:5XX一般为后台问题,可以把关键信息发送给后端,通知后端参与处理。

建议一次性发给后端的数据:

请求路径

请求方式

状态码

请求体(载荷):数据

响应体(预览)

🔔快速修复技巧

目标:原因已经确定,如果快速定位代码?

可以通过善用Source面板。

image-20230427160042150

image-20230427160353213

image-20230427160817178

二分注释法

目标:Bug是编码错误导致的。

推导1:删除掉所有的代码,应该不会有Bug存在。

推导2:删除掉错误的代码,应该不会有Bug存在。

程序员最头疼的Bug,没有报错,没有任何提示。

步骤:

  1. 通过不断注释代码,观察程序是否恢复正常
  2. 注释掉部分代码后,程序正常,证明该部分代码有Bug
  3. 在Bug部分,继续小部分的注释,观察程序是否正常。
  4. 持续1-3步骤,定位出Bug位置。
Loading...