前端调试技巧

news2025/1/11 3:59:49

前端工作中,不仅编码很重要,重现bug,解决bug的能力同样重要。而这些都离不开代码调试。本文就一些调试技巧做出总结,不足之处,欢迎大家多多补充。

PC调试

  • console.log()

    在你觉得有问题的代码处,加上一句 console.log() 就好了。然后在开发者工具控制台就可以看到你打印出来的东西了。

  • 断点调试

    • debugger 语句
      在代码中添加 debugger 语句,当代码执行到该语句的时候就会自动断点。

      我们需要关注上图红色方框内的七个按钮。从左到右依次标记为a,b,c,d,e,f,g。

      • a: Pause/Resume script execution:暂停/恢复脚本执行(程序执行到下一断点停止),快捷键F8。
      • b: Step over next function call:逐语句执行(跳到下一行),快捷键F10。
      • c: Step into next function call:进入当前函数,快捷键F11。
      • d: Step out of current function:跳出当前执行函数,快捷键F11+Shift。
      • e: Step 和b的作用一致,快捷键F9
      • f: Deactive/Active all breakpoints:关闭/开启所有断点。
      • g: Pause on exceptions:异常情况自动断点设置。

      此时,我们在 Scope 面板中可以看到该作用域下变量和函数的信息(鼠标悬浮在对应的变量上也可以看到)方便我们排查问题。

    • 手动断点
      打开开发者工具的 source 面板,在左侧目录树中找到对应的JS文件,在右侧对应文件的行号上单击即可实现断点的添加和删除。在添加断点之后,代码就会在断点处停止执行。

    • 事件断点
      在上图中点击 Event Listener Breakpoints ,然后选择我们需要监听的事件。之后当该事件被触发时,浏览器会帮我们自动在相应的js文件代码处打上断点。举个例子:我想在百度首页输入框中输入时,进行断点调试,就可以使用该功能。

    • 请求断点
      在上图中点击 XHR/fetch breakpoints ,然后添加对应的请求URL,之后当该请求发送的时候,就会自动断点。还是用百度举例:添加一个请求URL断点,然后刷新页面。

    • Dom 断点
      我们还可以对指定的 dom 节点进行断点设置,根据设置类型的不同,浏览器会在 dom 节点属性变化,子树变化,节点被移除三个时机帮我们进行断点。还是用百度举例:在指定 dom 节点上右击,选择 Break on ,选择对应的时机进行设置

  • 动画调试

    工作中肯定会遇到调试动画的场景,为了调试动画,经常一遍又一遍的刷新页面,其实大可不必,有更简单的办法。

    1. 打开开发者面板,开启命令行(Mac: Command+Shift+P ,Windows:Control+Shift+P )

    2. 输入 Animations ,选择 Show Animations,打开动画检查器

    3. 之后在页面发生的动画都会被其捕获,我们就可以在动画检查器中调试动画了

      区域1:控制动画的速度和播放;
      区域2:捕获的页面动画;
      区域3:动画的时间线;
      区域4:动画的实现细节;
      我们可以很方便的在这里将动画调试到满意的程度,然后复制对应的动画属性参数到代码中。

移动端H5调试

移动端H5本地调试和PC调试完全一样,我们在此讨论的是在webview中如何调试。

  • vConsole

    移动端H5页面运行在App的 webview 内,没有开发者工具可以让我们方便的调试(比如查看log,抓网络请求,查看cookie,Ua等等);因此 vConsole 等这类调试工具就产生了,让我们的调试变得方便了很多。

  • 手机连接电脑

    有了vConsole这类调试工具以后,基本上能解决大部分调试问题了。但还是存在一些情况,我们必须进行真机调试。比如在部分机型上页面直接白屏,vConsole还没有进行加载等等
    大致步骤如下:

    1: 手机连接电脑
    2: 手机打开开发者选项,允许USB调试
    3: 电脑打开 chrome://inspect
    4: 手机打开App内的H5页面
    5: 此时电脑端 chrome://inspect 页面会出现手机端页面的信息,点击 inspect 打开开发者面板即可
    复制代码
  • 模拟器

    实际工作中经常会出现用户的机型页面有问题,而我们因为各种原因并没有该用户对应的机型,这个时候模拟器就派上用场了。

node调试

Node 调试工具入门教程 推荐一下阮老师的文章,简单易懂。
简单说就是 node --inspect-brk xxx.js + chrome://inspect 。
举个例子,比如我想在 vue.config.js 中设置 cacheGroups,然后写了对应的正则或者 test 函数,但是打包之后的产物不符合预期,我想知道是哪里出了问题,此时就得调试打断点。

1. node --inspect-brk node_modules/.bin/vue-cli-service build

2. 打开浏览器,输入chrome://inspect  找到对应的target,然后inspect

3. 在vue.config.js 设置断点,进行问题排查
复制代码

vscode调试

  • node
    我们会发现上面调试node还是有点麻烦的,但是如果在编辑器中调试就很简单了。
    方法一:首先在对应文件行号左边单击,打上相应的断点;打开调试终端,直接运行命令。

    比如直接在 vue.config.js 中打上断点,然后打开调试终端,运行 npm run build

    方法二:打开运行和调试侧边栏,选择 Node.js 调试器

以上就是我们前端开发中经常用到的调试技巧,每种技巧都有对应的使用场景,不足之处,大家评论区多多补充,一起学习。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/447751.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于HFSS软件24GHz雷达天线设计

前言:近年来,我国的汽车保有量不断增加,汽车交通事故引发的财产损失和人 员伤亡也在不断增加。为了有效减少交通事故发生,车载雷达得到了各大汽车厂商和各个研究机构的普遍重视。现在国际上主要国家都把 24GHz 和 77GHz 两个频段分…

解决谷歌翻译不能使用的问题

今天登录国外网站,发现谷歌翻译已无法正常使用,网上最多的方法就是更改host文件,在host内增加ip地址,但是经常失效,经常手动更改增加ip着实烦恼,还有可能有别的错误。 最终解决方式是:登录GitH…

新版本ProPhet时间序列预测1:模型解释和安装和初步使用

ProPhet时间序列预测1安装和初步使用 安装pip安装conda安装 Prophet模型使用读取数据将数据处理为ds和y两列看下数据的分布模型训练预测可视化预测结果可视化趋势、假期、每周、季节性、年度季节性的回归图1.0之前模型保存 安装 安装1.0版本之后: 区别: 1.0版本叫prophet <…

设计模式-行为型模式之策略模式

5. 策略模式 5.1. 模式动机 完成一项任务&#xff0c;往往可以有多种不同的方式&#xff0c;每一种方式称为一个策略&#xff0c;我们可以根据环境或者条件的不同选择不同的策略来完成该项任务。 在软件开发中也常常遇到类似的情况&#xff0c;实现某一个功能有多个途径&#x…

【原理图专题】如何把PCB元件位号重排并反标到原理图

在画原理图时我们有时会复制以前项目或其他项目已经现成的模块进行电路的搭建。但可能会遇到一个问题,就是复制过来后位号也跟着过来了。比如说一个板子可能只有100个元件,但是会出现位号上千的元件。这对于后面我们焊接、维修等都很不利。 那可能有人会问,我直接在画完原理…

Redis持久化机制导致服务自启动后恢复数据过长无法使用以及如何关闭

场景 若依前后端分离版手把手教你本地搭建环境并运行项目&#xff1a; 若依前后端分离版手把手教你本地搭建环境并运行项目_霸道流氓气质的博客-CSDN博客 在上面搭建前后端分离的项目后&#xff0c;如果需要在windows服务上进行部署。 若依前后端分离版本&#xff0c;Windo…

58 openEuler搭建Mariadb数据库服务器-管理数据库

文章目录 58 openEuler搭建Mariadb数据库服务器-管理数据库58.1 创建数据库58.2 查看数据库58.3 选择数据库58.4 删除数据库58.5 备份数据库58.6 恢复数据库 58 openEuler搭建Mariadb数据库服务器-管理数据库 58.1 创建数据库 可以使用CREATE DATABASE语句来创建数据库。 CR…

Jetson Nano (4GB)烧写jetbot Image

一、Image下载 1、官方下载&#xff0c;浏览器访问Using SD Card Image - JetBot&#xff0c;下载jetbot-043_nano-4gb-jp45.zip。 注意&#xff1a;通过此方式下载需要电脑能访问外网。 2、天翼网盘下载&#xff0c;https://cloud.189.cn/t/q2mUJv7jaIna &#xff08;访问码…

【三十天精通Vue 3】 第十五天 Vue 3的异步组件和代码拆分

✅创作者&#xff1a;陈书予 &#x1f389;个人主页&#xff1a;陈书予的个人主页 &#x1f341;陈书予的个人社区&#xff0c;欢迎你的加入: 陈书予的社区 &#x1f31f;专栏地址: 三十天精通 Vue 3 文章目录 引言一、Vue 3 中的异步组件1.1 异步组件的概念1.2 Vue 3 中的异步…

Python机器学习、深度学习技术提升气象、海洋、水文领域应用

Python是功能强大、免费、开源&#xff0c;实现面向对象的编程语言&#xff0c;能够在不同操作系统和平台使用&#xff0c;简洁的语法和解释性语言使其成为理想的脚本语言。除了标准库&#xff0c;还有丰富的第三方库&#xff0c;Python在数据处理、科学计算、数学建模、数据挖…

设计模式--原型模式

目录 基本介绍 传统方式克隆 原型模式改进 浅拷贝和深拷贝 浅拷贝的介绍 深拷贝的介绍 原型模式的注意事项和细节 基本介绍 (1) 原型模式(prototype模式): 用原型实例指定创建对象的种类 并且通过拷贝这些原型 创建新的对象 (2) 原型模式是一种创建型设计模式 允许一个…

妙用Java 8中的 Function接口,消灭if...else

在开发过程中经常会使用if...else...进行判断抛出异常、分支处理等操作。这些if...else...充斥在代码中严重影响了代码代码的美观&#xff0c;这时我们可以利用Java 8的Function接口来消灭if...else...。 if (...){throw new RuntimeException("出现异常了")&#x…

全网详细解决1093 - You can‘t specify target table ‘xxx‘ for update in FROM clause的错误

文章目录 1. 复现错误2. 分析错误3. 解决错误 1. 复现错误 今天在工作时&#xff0c;接到一个新需求&#xff0c;就是将app_page_button表中的label_code字段修改为edit&#xff0c;条件如下&#xff1a; 只更新值为null的label_code 且以/edit/${id}结尾的option_value 首先…

基于微信小程序+爬虫制作一个表情包小程序

跟朋友聊天斗图失败气急败坏的我选择直接制作一个爬虫表情包小程序,从源头解决问题,从此再也不用担心在斗图中落入下风 精彩专栏持续更新↓↓↓ 微信小程序实战开发专栏 一、API1.1 项目创建1.2 图片爬虫帮助类1.3 测试窗体1.4 接口封装二、小程序2.1 项目创建2.2 页面设计2.…

css 实现太极效果

目录 一、简述二、太极效果制作 一、简述 本次主要介绍::after&#xff0c;::before&#xff0c;box-shadow这三个属性。 ::after&#xff0c;::before这两个是伪类选择器&#xff0c;box-shaow是用来设置元素的阴影效果 before:向选定的元素前插入内容 after:向选定的元素后插…

关于在线CAD编辑的解决方案思考

基于ODA的VisualizeJs库的能力 ODA官网的OpenCloud提供了在线浏览CAD图纸的能力(ODA自身也不支持直接在线解析Dwg&#xff0c;而是通过ODA提供的WebTools里面的FileConverter的能力将dwg图纸转换为VSF格式(CAD的一种二三维格式&#xff0c;在AutoCAD中也有一种类似的ForgeView…

chatGPT衣食住行10种场景系列教程(01)使用chatGPT设计发型、P图变漂亮~真帅哈哈哈~

导读 时隔5个多月&#xff0c;chatGPT可谓是一日千里&#xff0c;越演越火&#xff0c;携带着AIGC行业一起飞了起来&#xff0c;那么在短短5个月当中有那些值得我们关注的事件&#xff1f;有那些好玩的场景&#xff1f;以及有那些chatGPT好用的工具&#xff1f;本文都将一一告…

neo4j数据库的安装及使用

一、安装neo4j 安装neo4j数据库&#xff0c;需要先安装jdk&#xff0c;jdk版本不能太低&#xff0c;不然运行neo4j的时候会报错。 我下载的是jdk11&#xff0c;以前已经下载过了&#xff0c;这里不再进行演示&#xff0c;下载jdk11的教程应该挺多的&#xff0c;自己搜一个吧 …

nodejs+vue美容院预约管理系统springboot+java+python

本课题将根据用户类型大致划分为管理员模块和美容师模块和用户模块&#xff0c;开发语言拟采用目前比较 语言 node.js 框架&#xff1a;Express 前端:Vue.js 数据库&#xff1a;mysql 数据库工具&#xff1a;Navicat 开发软件&#xff1a;VScode &#xff0c;界面采用vue前端框…

jsp+servlet教材预定系统mysql

目 录 一、引言 6 (一) 课题目的及意义 6 1、课题目的 6 2、课题研究意义 6 (二) 国内外研究现状 6 1、国外研究现状 6 2、国内研究现状 7 (三) 研究方法及设计思路 7 1、研究方法 7 2、设计思路 8 二、需求分析与可行性分析 9 (一) 需求分析…