当前位置: 首页 > ds >正文

【前端debug调试】

调试入门秘籍

Chrome DevTool调试工具

效果图:
在这里插入图片描述

两种打开方式:

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

修改停靠位置:
在这里插入图片描述

调试工具的基本功能介绍

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

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

如下图:
在这里插入图片描述


元素 (Element)

作用:快速调试样式

注意:刷新会丢失

实用小技巧:🔔🔔

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

在这里插入图片描述

控制台(Console)

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

实用小技巧:🔔🔔

  1. 可以当做计算器
  2. 可以运行代码
    在这里插入图片描述

如何打印不同的颜色?

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

如何打印一个DOM元素?

	const h1Node = document.querySelector('h1')// JS中万物皆对象// dir专门打印对象console.dir(h1Node)function hello() { }console.dir(hello)

源代码 (Source)

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

需要掌握的操作按钮:
在这里插入图片描述

上面有几个控制执行的按钮,分别是:
在这里插入图片描述

网络 (NetWork)

知识补充:浏览器与服务器通过HTTP协议通信流程
在这里插入图片描述

访问示例网站,观察请求信息:

浏览器发的请求信息展示
在这里插入图片描述
在这里插入图片描述

服务端响应的信息展示:

在这里插入图片描述
在这里插入图片描述

了解的HTTP状态码有哪些?

扩展:完整的状态码

成功(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项目中的报错

常见错误有3~4类:

  1. SyntaxError(语法错误)
    在这里插入图片描述

  2. ReferenceError (引用错误)
    在这里插入图片描述

  3. TypeError (类型错误)
    在这里插入图片描述

  4. RangeError (死循环)
    在这里插入图片描述

小结:

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

小技巧🔔:

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

认识-类库兼容问题

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

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

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

报错信息中无源码文件提示,无常见错误提示。如下图
在这里插入图片描述

如何解决此类问题?

  • 面向百度编程、面向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字段
快速修复技巧

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

可以通过善用Source面板。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

状态码5XX

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

状态码2XX

目标:2XX一般代表成功,但也不绝对。

定位:以预期数据与实际数据,是否相符合为准。

二分注释法

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

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

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

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

步骤:

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

相关文章:

  • 如何解决pip安装报错ModuleNotFoundError: No module named ‘arviz’问题
  • 网站速度慢?安全防护弱?EdgeOne免费套餐一次性解决两大痛点
  • chapter05_从spring.xml读取Bean
  • 完整实验命令解析:从集群搭建到负载均衡配置
  • Java:类及方法常见规约
  • Unity中删除不及时的问题
  • 牛客面经2 京东社招-002
  • PyTorch框架之图像识别模型与训练策略
  • 25.深入对象
  • 寻找AI——高保真还原设计图生成App页面
  • 华为/思科/H3C/锐捷操作系统操作指南
  • 鸿蒙应用网络开发实战:HTTP、WebSocket、文件下载与网络检测全攻略
  • 微信小程序和uni-app面试问题总结
  • 网络模型深度解析:CNI、Pod通信与NetworkPolicy
  • Spring Boot 实时广播消息
  • Java集合(Collection、Map、转换)
  • git实战(7)git常用命令速查表
  • GitHub发布革命性工具:GitHub Spark,用自然语言打造全栈智能应用
  • 商品与股指类ETF期权买卖五档Tick分钟级历史行情数据分析
  • Node.js 和 Express 面试问题总结
  • 目标跟踪 YOLO11 单目标跟踪
  • Maven仓库与Maven私服架构
  • Spring Boot 实现 POJO 级联封装复杂属性
  • React Hooks UseRef的用法
  • 高速CANFD收发器ASM1042在割草机器人轮毂电机通信系统中的适配性研究
  • 终结系统裸奔:Debian老旧版本安全加固终极指南
  • 梯度下降(线性回归为例)
  • 总结:Maven多仓库多镜像源配置
  • 【KO】前端面试五
  • MySQL存储过程详解