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

【前端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.dtcms.com/a/347728.html

相关文章:

  • 【Java SE】抽象类、接口与Object类
  • 从“一指禅”到盲打:如何系统提升电脑输入能力?
  • 25.深入对象
  • 联邦学习之----联邦批量归一化(FedBN)
  • 线程间Bug检测工具Canary
  • Python字符串
  • SOC估算方法-蜣螂优化算法结合极限学习
  • 1200 SCL学习笔记
  • 机器人控制基础:串级PID控制算法的参数如何整定?
  • 11.Shell脚本修炼手册---IF 条件语句的知识与实践
  • 无线数传模块保障智能立体车库多设备实时通信的可靠性
  • 二、BPMNJS简介
  • share logic in core or in example
  • 【typenum】 23 倒序存储的无符号整数(private.rs片段)
  • Linux mount 命令
  • PyInstaller将.py文件转为exe,执行文件在不同的电脑出现字体大小不一致问题原因分析及解决办法
  • Spring:IOC(控制反转 )、DI(依赖注入 )、AOP(通知类型、事务、拦截器)
  • 主流.NET 平台的NuGet 生态正在积极拥抱 AOT
  • 【84页PPT】智慧方案某著名企业某集团协同OA整体解决方案(附下载方式)
  • MySQL索引原理与优化全解析
  • 【每天一个知识点】训推一体机
  • 13.Shell脚本修炼手册---玩转 CASE 语句(应用场景与实践技巧)
  • GitHub Actions workflow最佳实践
  • 提问:温度不改变 logits 与概率的排名,为何还会影响模型输出?
  • Linux 进程间通信之System V 共享内存
  • 深入探讨集成学习:Bagging与Boosting的核心原理与实践
  • RAG系统开发中的12大痛点及应对策略
  • SVG.js 一个轻量且强大的图形库
  • Sql server的行转列
  • word——表格跨页显示表头