利用vscode调试编译后的js代码详解


Posted in Javascript onMay 14, 2018

前言

在开发的过程中,几乎不可能一次性就能写出毫无破绽的程序,断点调试代码是一个普遍的需求。

vscode 是一个非常棒的编辑器,内置功能强大的调试能力。经过简单的设定,就可以对 js 文件进行调试。但有时我们想要调试的内容是经过编译的,当然我们可以直接调试编译后的代码。但经过编译压缩以后的代码,可读性很差,且也可能无法分模块查看了,有什么方法进行编译前的代码调试么?答案当然是肯定的。

下面话不多说了,来一起看看详细的介绍吧。

vscode 的常规调试

vscode 的调试界面在窗口最左边:

利用vscode调试编译后的js代码详解

最新版本的vscode,该选项默认隐藏了,需要自己打开。

首次打开调试界面时,当前没有任何调试配置,我们可以点击齿轮 icon 添加一个:

利用vscode调试编译后的js代码详解

选择 nodejs 后,会自动在当前工程目录下添加 .vscode/launch.json 文件,这个文件就是 vscode 调试配置文件。

一个简易的配置文件内容为:

{
 // 使用 IntelliSense 了解相关属性。 
 // 悬停以查看现有属性的描述。
 // 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
 "version": "0.2.0",
 "configurations": [
 {
 "type": "node",
 "request": "launch",
 "name": "启动程序",
 "program": "${workspaceFolder}/index.js"
 }
 ]
}

上面这个配置所做的工作是启动当前目录下的 index.js 文件进行调试。

我们也可以设置每次摁 F5 时自动调试当前打开的文件,只需要修改 program:

{
 "program": "${file}"
}

调试编译后的文件

想要调试编译后的文件,需要对 launch.json 文件进行设置。

vscode 要想调试编译后的代码,他需要知道哪些代码是经过编译的,且需要知道编译后的代码与编译前代码的对应关系。

其实理论上 vscode 是可以把每个要执行的文件都认为是编译后的文件,进行源文件的查找?我猜是因为性能原因,我们需要自己指定哪些文件是编译后的文件。在 launch.json 中,使用outFiles属性来指定编译后的产出文件:

{
 "version": "0.2.0",
 "configurations": [
 {
 // 省略其他设置...
 "outFiles": [
 "${workspaceFolder}/lib/*.js",
 ]
 // ...
 }
 ]
}

虽然有些麻烦,但好在我们可以使用通配符。

现在有了编译后的文件,vscode 还需要知道源文件,以及编译后文件与源文件的对应关系,听着有没有很熟悉?这个过程就是通过 sourcemap 来进行实现的。

我们需要在编译 js 文件时生成相应的 .map 文件,并在产出 js 文件后面附加 .map 文件的地址:

//@ sourceMappingURL=./index.js.map

ok,现在 vscode 在执行 js 文件时,会从 outFile 中查找是否是编译后的代码,如果是,就通过 sourcemap 映射到源代码,方便我们进行调试。

自动执行编译

现在我们的开发流程变成了:修改源代码 -> 编译源代码 -> 调试。

为了方便,我们可以设置preLaunchTask属性,该属性的作用是每次调试前执行一个前置任务,我们可以把编译过程放在前置任务里。

首先我们需要来配置一个task,task的配置文件在 .vscode/tasks.json,可以打开 command palette (⇧⌘P (Windows, Linux Ctrl+Shift+P)) 选择“任务:配置任务”自动生成一个:

{
 // See https://go.microsoft.com/fwlink/?LinkId=733558
 // for the documentation about the tasks.json format
 "version": "2.0.0",
 "tasks": [
 {
 "label": "build",
 "type": "npm",
 "script": "build",
 "problemMatcher": []
 }
 ]
}

这里我们配置了npm run build作为前置任务,每次执行调试时都会先进行 build。

示例配置文件

{
 // 使用 IntelliSense 了解相关属性。 
 // 悬停以查看现有属性的描述。
 // 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
 "version": "0.2.0",
 "configurations": [
 {
 "type": "node",
 "request": "launch",
 "name": "example",
 "program": "${workspaceFolder}/index.js",
 "preLaunchTask": "build",
 "cwd": "${workspaceFolder}",
 "outFiles": [
 "${workspaceFolder}/lib/*.js"
 ]
 }

相关文档

  • Debugging in Visual Studio Code
  • Tasks in Visual Studio Code

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
js的event详解。
Sep 06 Javascript
JavaScript计算字符串中每个字符出现次数的小例子
Jul 02 Javascript
JavaScript类型系统之布尔Boolean类型详解
Jun 26 Javascript
Webpack+Vue如何导入Jquery和Jquery的第三方插件
Feb 20 Javascript
JS中使用正则表达式g模式和非g模式的区别
Apr 01 Javascript
react-router实现跳转传值的方法示例
May 27 Javascript
JavaScript实现数值自动增加动画
Dec 28 Javascript
Vue 3.x+axios跨域方案的踩坑指南
Jul 04 Javascript
vue之a-table中实现清空选中的数据
Nov 07 Javascript
Vue实现点击箭头上下移动效果
Jun 11 Javascript
深入解读VUE中的异步渲染的实现
Jun 19 Javascript
JS相册图片抖动放大展示效果的示例代码
Jan 29 Javascript
vue的toast弹窗组件实例详解
May 14 #Javascript
Vue页面骨架屏注入方法
May 13 #Javascript
浅谈在node.js进入文件目录的问题
May 13 #Javascript
解决node修改后需频繁手动重启的问题
May 13 #Javascript
垃圾回收器的相关知识点总结
May 13 #Javascript
基于node搭建服务器,写接口,调接口,跨域的实例
May 13 #Javascript
深入理解js 中async 函数的含义和用法
May 13 #Javascript
You might like
用PHP制作的意见反馈表源码
2007/03/11 PHP
基于php设计模式中单例模式的应用分析
2013/05/15 PHP
php比较两个绝对时间的大小
2014/01/31 PHP
PHP检查网站是否宕机的方法示例
2017/07/24 PHP
PHP接口继承及接口多继承原理与实现方法详解
2017/10/18 PHP
JSON PHP中,Json字符串反序列化成对象/数组的方法
2018/05/31 PHP
在html页面上拖放移动标签
2010/01/08 Javascript
jquery ajax abort()的使用方法
2010/10/28 Javascript
在JS中最常看到切最容易迷惑的语法(转)
2010/10/29 Javascript
基于jQuery的图片大小自动适应实现代码
2010/11/17 Javascript
自己使用jquery写的一个无缝滚动的插件
2014/04/30 Javascript
详解JS获取HTML DOM元素的8种方法
2017/06/17 Javascript
JS实现运动缓冲效果的封装函数示例
2018/02/18 Javascript
JavaScript函数apply()和call()用法与异同分析
2018/08/10 Javascript
vue-cli 引入jQuery,Bootstrap,popper的方法
2018/09/03 jQuery
JS document对象简单用法完整示例
2020/01/14 Javascript
Python中的集合类型知识讲解
2015/08/19 Python
在类Unix系统上开始Python3编程入门
2015/08/20 Python
[原创]pip和pygal的安装实例教程
2017/12/07 Python
Django rest framework实现分页的示例
2018/05/24 Python
python3人脸识别的两种方法
2019/04/25 Python
python实现TCP文件传输
2020/03/20 Python
python基于openpyxl生成excel文件
2020/12/23 Python
纯CSS3制作页面切换效果的实例代码
2019/05/30 HTML / CSS
HTML5 video播放器全屏(fullScreen)方法实例
2015/04/24 HTML / CSS
html2 canvas生成清晰的图片实现打印功能
2019/09/23 HTML / CSS
美国最大的在线水培用品商店:GrowersHouse.com
2018/08/14 全球购物
Priority Pass机场贵宾室会籍计划:全球超过1200间机场贵宾室
2018/08/26 全球购物
党的群众路线教育实践活动组织生活会发言材料
2014/10/17 职场文书
八达岭长城导游词
2015/01/30 职场文书
财务稽核岗位职责
2015/04/13 职场文书
信访维稳承诺书
2015/05/04 职场文书
入党积极分子培养联系人意见
2015/08/12 职场文书
初中地理教学反思
2016/02/19 职场文书
Mysql 一主多从的部署
2022/05/20 MySQL
JS前端轻量fabric.js系列物体基类
2022/08/05 Javascript