前端瓶子君,关注公众号
回复算法,加入前端编程面试算法每日一题群
VsCode自从诞生以来,以其各自优异的特性迅速走红。尤其是对于前端开发小伙伴来说,几乎成为必不可少的开发工具。所以,熟练掌握VsCode的各自使用技巧与调试技巧会让你的日常开发工作效率倍增。本文将会以大量图文的方式,从下面几个方面详细介绍VsCode的各种技巧:
第一部分主要介绍VsCode的基本技巧,比如常用快捷键、辅助标尺等。熟悉此部分的可以直接跳过。
第二部分主要各种断点(比如日志断点、内联断点、表达式断点等等)、数据面板等等
第三部分主要讲解各种项目的调试实战,比如Node程序、TS程序、Vue程序、Electron程序、Html等的调试实战
最后一部分将会讲解其他有用的技巧,比如代码片段、重构、Emmet等等
基本技巧
快速启动
VsCode安装后,会自动写入环境变量,终端输入code
即可唤起VsCode应用程序。
常用快捷键
ctrl + p
快速搜索文件并跳转,添加:
可以跳转到指定行
data:image/s3,"s3://crabby-images/ce203/ce203e62df6497231277eab285327386c1fbf246" alt="74e6324e1fb4dcf754e934cd3b5c76c7.png"
ctrl + shift + p
根据您当前的上下文访问所有可用命令。ctrl + shift + c
在外部打开终端并定位到当前项目路径ctrl + 按键1左边的符号
显示隐藏终端面板Ctrl+B
切换侧边栏Ctrl+\
快速拆分文件编辑alt + 单机左键
添加多处光标alt + shift + 单击左键
同一列所有位置添加光标alt + shift + 鼠标选择
选择相同开始和结束的区域
data:image/s3,"s3://crabby-images/6f7c6/6f7c61b98e8ebce30c82a082063633eb9a9608d3" alt="b4572b05f41d18ee805fc257741cd5bf.png"
alt + 上键或下键
将当前行或者选中的区域上移/下移一行
垂直标尺
在配置文件中添加如下配置,可以增加字符数标尺辅助线
"editor.rulers": [40, 80, 100]
复制代码
data:image/s3,"s3://crabby-images/64da1/64da141a096a884debf796b25edfd0c6be19ccb7" alt="816f9756bae092facd4838f462214344.png"
进阶技巧
断点的基本使用
下面以在VsCode中快速调试一个Node项目为例,演示断点的基本使用。后文会继续结束各种高级断点。
创建一个基本的node项目为Nodejs
打开左侧调试面板,选择你要调试的node项目名称,添加调试配置
data:image/s3,"s3://crabby-images/4c51b/4c51bb4a87ad7ddb4f0e0cf8f54599feab71d30b" alt="3a1917e785fb84698b841cc2a16c3234.png"
选择调试的项目类型为Node.js
data:image/s3,"s3://crabby-images/431c3/431c381b1e518c92a8ee56f8df6bcd5e491fedf3" alt="c9f9ddcdb389bea23c3de91dbf8f8c15.png"
打开生成的.vscode/launch.json文件,指定程序入口文件
program
字段用于指定你的程序入口文件,${workspaceFolder}
表示当前项目根路径
data:image/s3,"s3://crabby-images/1c015/1c0151aa2edd7ff802e508f4e1c3d7deac245c2a" alt="6341bf32cc85eaa636aa2cb2e551f14c.png"
在程序中添加断点,只需要点击左侧的边栏即可添加断点
data:image/s3,"s3://crabby-images/5a89f/5a89faabd380918055105704d6186e927a9c3755" alt="3eb66eb0acaf4a82c09d77583a551298.png"
按
F5
开始调试,成功调试会有浮窗操作栏
data:image/s3,"s3://crabby-images/5e243/5e24344baa2a8099741db4bd2df7f52044163882" alt="7b3a2861c97a660231e20c554c1f3cdd.png"
浮窗的操作按钮功能依次为:
继续(
F5
)、调试下一步(
F10
)、单步跳入(
F11
)、单步跳出(
Shift F11
)、重新调试(
Ctrl + Shift + F5
)、结束调试(
Shift + F5
)
日志断点
日志断点是普通断点的一种变体,区别在于不会中断调试,而是可以把信息记录到控制台。日志断点对于调试无法暂停或停止的服务时特别有用。步骤如下:
添加日志断点的步骤
data:image/s3,"s3://crabby-images/d7f20/d7f20e11510f4b15e646f8f9c5e4c817ff4daf97" alt="e8d8d0454b5b6ab8f538fb63b7f20402.png"
输入要日志断点的信息,点击回车添加完成
可以使用{}
使用变量,比如在此处添加日志断点,b的值为${b}
data:image/s3,"s3://crabby-images/0d7ef/0d7ef1f659f792e71c2f1742278f245a50dbbec9" alt="59ca1e7d1bcc7e75b63c5c770732dace.png"
日志断点添加成功后会有是一个菱形图标
data:image/s3,"s3://crabby-images/1b72a/1b72a64544f86c02400575b76a538653c032fa99" alt="282585756ee7c1fdd2b9370a643f886b.png"
按
F5
运行查看调试结果
data:image/s3,"s3://crabby-images/11cce/11cce5c6eafc2c806f2e1a0d420a00c2d294e0e2" alt="20dc04de5b4edde8ed16dae52b1e325f.png"
表达式条件断点
条件断点是表达式结果为true
时才会进行断点,步骤如下:
在代码行左侧右击,也可以添加断点,此处选择添加条件断点
data:image/s3,"s3://crabby-images/55870/55870e1abb93b085ba50a1a6ecfcf0aa408abcbb" alt="4e42b43c2467f095ae17a09302185826.png"
填写表达式,按回车键
data:image/s3,"s3://crabby-images/cc5b8/cc5b8c1f2ddaa411cd35bb8b063a716218784941" alt="06b0188d8e8fb5da51f3b46944510aad.png"
添加成功的小图标如下
data:image/s3,"s3://crabby-images/5dc04/5dc046fa776890b15b4b3ebf123d91e951190093" alt="cde44aa09d19dac7f3ad8a0ece3fa162.png"
按
F5
调试,条件成立所以进行了断点
data:image/s3,"s3://crabby-images/93610/936106b5bdd8aaf5c972941105760079127a7c8c" alt="3c91d1a50b93eca78bd196996bf7a5a0.png"
命中计数断点
只有该行代码命中了指定次数,才会进行断点。步骤如下:
选择条件断点,切换为命中次数选项,填写命中次数
data:image/s3,"s3://crabby-images/3f105/3f105150870c7bddbef234ccebcc625a374988e8" alt="875532fc3b139a306f200bc70dd98b22.png"
填写成功如下图所示
data:image/s3,"s3://crabby-images/e6cd7/e6cd700576e32508eb3183dec7a1040af1b7df43" alt="068b86df712224bd32e5b9ac08bfc624.png"
按
F5
调试,如图所示,index为9时才中断
data:image/s3,"s3://crabby-images/d5514/d5514a8d8d42a33fb85317a03be9801660e4ebb6" alt="9678621afc551380500d3aaf2e683103.png"
内联断点
仅当执行到达与内联断点关联的列时,才会命中内联断点。这在调试在一行中包含多个语句的缩小代码时特别有用。比如for循环,短路运算符等一行代码包含多个表达式时会特别有用。步骤如下:
在指定位置按
Shift + F9
data:image/s3,"s3://crabby-images/190b3/190b32a0d80e401230ed3e68f3c41063a95aa09e" alt="8e3f9106e48f734d52d2fa273de9d872.png"
调试之后,每次运行到该内联处的代码都会中断
data:image/s3,"s3://crabby-images/61207/61207b58f1049b37599819ee221a55da02b7bcf7" alt="0b4c77131aca9e29bb70ffc77d8a2c20.png"
补充知识点:数据面板介绍
数据面板可以查看所有变量
data:image/s3,"s3://crabby-images/2e2ad/2e2adc1dd28a661bf7d42209864a43416f5428b5" alt="b27ea267570954189866f9e2ba8c3c43.png"
在变量上点击右键,可以设置变量值、复制变量值等操作
data:image/s3,"s3://crabby-images/11225/112256319789375d0fa8965d927be515ee2035c6" alt="e8045c741788cae6dc0c299cf0d9cb06.png"
聚焦于数据面板时,可以通过键入值来搜索过滤。点击下图所示按钮可以控制是否筛选。
data:image/s3,"s3://crabby-images/656b4/656b4cf64ab31b31ab474080b3abdd257261d2fd" alt="c27e30e66803d119b9db493b2e4dd896.png"
data:image/s3,"s3://crabby-images/ba371/ba371d2bc50dedecd7119b40bdb6088585eba584" alt="a4b8a72b5a71f4c9a3103ac59146b234.png"
补充知识点:监听面板介绍
可以将变量添加到监听面板,实时观察变量的变化。
在变量面板通过右键选择“添加到监视”将变量添加到监听面板
data:image/s3,"s3://crabby-images/ddd45/ddd45bde5e68d771194cd8ed7d4fa1402ed40614" alt="672b0814fa85906f6814f8d9a2ad1538.png"
也可以直接在监听面板选择添加按钮进行变量添加
data:image/s3,"s3://crabby-images/ba701/ba7013b6b70506d3f47df0c49f1e5e6ccc30810e" alt="035d7e8348c7679d075521fdad568e78.png"
添加变量后就可以实时监听变量的变化
data:image/s3,"s3://crabby-images/c0cfb/c0cfb1742d47d9115432b26088dc98433e0eb193" alt="da33fa24e7e66ee92303a7ff3b00855b.png"
补充知识点:调试服务器时打开一个URI
开发 Web 程序通常需要在 Web 浏览器中打开特定 URL,以便在调试器中访问服务器代码。VS Code 有一个内置功能“ serverReadyAction ”来自动化这个任务。
一段简单的server代码
var express = require('express');
var app = express();
app.get('/', function(req, res) {
res.send('Hello World!');
});
app.listen(3000, function() {
console.log('Example app listening on port 3000!');
});
复制代码
配置launch.json,以支持打开URI
{
"type": "node",
"request": "launch",
"name": "Launch Program",
"program": "${workspaceFolder}/app.js",
"serverReadyAction": {
"pattern": "listening on port ([0-9]+)",
"uriFormat": "http://localhost:%s",
"action": "openExternally"
}
}
复制代码
pattern
是设置匹配的程度端口号,端口号放在小括号内,即作为一个正则的捕获组使用。uriFormat
映射为URI,其中%s
使用pattern
中的第一个捕获组替换。最后使用该URI作为外部程序打开的URI。
按
F5
调试,会自动打开浏览器,且会在下图所示处中断,当继续执行后,浏览器才能看到输出了server的内容
data:image/s3,"s3://crabby-images/4a08e/4a08ea9d27a9657852169747052bb349d9fd9b09" alt="ef6bf2aca1ef81525e0b7e7a6d1dfc17.png"
终局:各场景调试实战
调试NodeJS项目
关于NodeJs项目的调试方法,已经在上述的断点的基本使用[1]部分做了介绍,可以网上滚动翻阅。
调试Typescript项目
调试TS项目前,先创建一个TS项目
# 终端运行 tsc --init 复制代码
VS Code 内置了对 Ts 调试的支持。为了支持调试 Ts 与正在执行的 Js 代码相结合,VS Code 依赖于调试器的source map在 Ts 源代码和正在运行的 Js 之间进行映射,所以需要需要开启
sourceMap
选项。{ "sourceMap": true, "outDir": "./out" } 复制代码
const num: number = 123; console.log(num); function fn(arg: string): void { console.log('fn', arg); } fn("Hello"); 复制代码
新建index.ts文件,写一个基本的ts代码
打开
tsconfig.json
文件,开启sourceMap选项和指定编译后输出的路径先初始化一个ts程序,生成默认的
tsconfig.json
文件
手动编译调试TS
在上述的ts基本项目中:
image.png image.png image.png image.png 按
F5
或者运行 -> 启动调试
,此时可以看到可以正常debug调试在index.ts中随意添加一个断点
此时可以看到生成了out文件夹,里面包含一个
index.js
和一个index.js.map
文件终端执行ts的编译命令
tsc
通过构建任务构建调试TS
image.png image.png 注意,如果你使用的是其他终端(比如
cmder
)的话,有可能会生成不了,如下图所示,使用默认的powershell即可:image.png 调试的话和上述步骤一样,在有了编译后的文件后,按
F5
即可选择
tsc构建选项
,此时可以看到自动生成了编译文件按
Ctrl+Shift+B
或选择终端 -> 运行生成任务
,此时会弹出一个下拉菜单
监视改变并实时编译
image.png image.png 如下图所示,会实时编译
按
Ctrl + Shift + B
选择监视选项,可以实时监视文件内容发生变化,重新编译
补充知识点:tasks配置文件的创建方式
方法1:点击
终端 -> 配置任务 -> 选择任务
可以生成对应的tasks.json配置
data:image/s3,"s3://crabby-images/03b53/03b53592bc3a28bc5873e4f20bfef8e17a24ec0a" alt="16bed39bb0627cd4e911beb3a8119ba7.png"
data:image/s3,"s3://crabby-images/309a6/309a63be1460a783fdb2db63ad69fe5c83a2853e" alt="bc9abc362a5f3be1ce96b1a0176ed2fb.png"
方法2:点击
终端 -> 运行生成任务 -> 点击设置图标
也可以生成对应的tasks.json配置
data:image/s3,"s3://crabby-images/cad5c/cad5c1818945943179a7ec2bb23da2c5a2223f2a" alt="008e297ccbf06b5ce73d784a8e8b95d6.png"
data:image/s3,"s3://crabby-images/44575/44575642e306030658bb32318cb9c4e3eb33b9ff" alt="8feb30297f3336264b34b0e33639f874.png"
补充知识点:每次调试时重新编译
按上述的操作已经生成了task.json配置文件
{
"version": "2.0.0",
"tasks": [
{
"type": "typescript",
"tsconfig": "tsconfig.json",
"problemMatcher": [
"$tsc"
],
"group": "build",
"label": "tsc: 构建 - tsconfig.json"
}
]
}
复制代码
点击
运行 -> 添加配置 -> 选择nodejs
data:image/s3,"s3://crabby-images/7d9e8/7d9e8be71ac62ef8218d3f2310ffd6e62385071d" alt="b2e1f4d96e568e9f8ad1c88e6d3dd1dd.png"
在生成的
launch.json
文件中,添加preLaunchTask
字段,值是tasks.json
的label
值,一定要相同,注意大小写。该字段的作用是在执行命令前先执行改task
任务。
data:image/s3,"s3://crabby-images/45ab5/45ab5bc604021791195d20b6e564cfa0e42f8f0d" alt="532d8056cb9b58439a445b18f8564c78.png"
注意,如果编译后的js文件不在相应的位置,通过图中的outFiles
字段可以指定ts
编译后的js
路径。
在
index.ts
文件中按F5
启动调试,可以看到调试前已经生成了编译文件,而后就可以正常调试了。
data:image/s3,"s3://crabby-images/909b0/909b0bbfef9c8b00d674b41ac39bc9588851c66d" alt="bc4e26c2f4e0acfc93e88474457f3088.png"
补充知识点:VsCode的TS版本说明
vscode本身内置了对ts的支持
vscode内置的ts版本(即工作区版本),仅仅用于IntelliSense(代码提示),工作区ts版本与用于编译的ts版本无任何关系。
修改工作区ts版本的方法:
在状态栏选择typescript的图标,选择版本切换
data:image/s3,"s3://crabby-images/322d6/322d6f87da11e7a8e540beafe34738c6e704bc62" alt="86475416d3549eb2a8916245d9efca4d.png"
选择你需要的版本即可
data:image/s3,"s3://crabby-images/66f29/66f29848f8ab5dceb51a4cec78d72086b85b57b0" alt="38d8b08319edd2a3c4f163f03e2e23db.png"
data:image/s3,"s3://crabby-images/04741/04741ecee2d35aa807a04c774796dd250ba3bdd0" alt="f44ea05096784b7b0a1d007b1740e202.png"
调试html项目
学会了上述ts的调试后,我们尝试调试html文件,并且html文件中引入ts文件:
创建html,引入ts编译后的js文件
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<h3>Hello</h3>
<script src="./out/index.js"></script>
</body>
</html>
复制代码
ts源文件如下:
const num: number = 1221;
console.log(num);
function fn(arg: string): void {
console.log('fn', arg);
}
document.body.append('World')
fn("he");
复制代码
打debug
data:image/s3,"s3://crabby-images/b6e12/b6e12378e3f9d737a61e4fb64eaed210a3e01f53" alt="70633b02499e92cade4857365d24046f.png"
launch.json启动命令配置
{
// 使用 IntelliSense 了解相关属性。
// 悬停以查看现有属性的描述。
// 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
"version": "0.2.0",
"configurations": [
{
"type": "pwa-chrome",
"request": "launch",
"name": "Launch Chrome",
"url": "file:///E:/demo/vscode/debug/ts/index.html",
"preLaunchTask": "tsc: 构建 - tsconfig.json",
"webRoot": "${workspaceFolder}"
}
]
}
复制代码
选择我们的启动命令
data:image/s3,"s3://crabby-images/c0e4b/c0e4bce65b5e6e9222e2fdb9dba87e6f9756870b" alt="ed21e05b10436ef2d4fccab188688f9b.png"
按
F5
可以正常唤起chrome浏览器,并在vscode的ts源码处会有debug效果
调试Vue项目的两种方式
下面介绍两种调试vue2项目的3种方法,其他框架的调试也类似:
不使用vscode插件Debugger for chrome的方法
初始化vue项目,配置
vue.config.js
,指定要生成sourceMaps资源
module.exports = {
configureWebpack: {
// 生成sourceMaps
devtool: "source-map"
}
};
复制代码
根目录下创建
./vscode/launch.json文件
或者选择运行 -> 添加配置 -> Chrome
data:image/s3,"s3://crabby-images/e479c/e479cd11a66edad1a322eb05915e691dea5ba94d" alt="409eef96b8ba2b9a7c7f05713fc89432.png"
{
"version": "0.2.0",
"configurations": [
{
"type": "chrome",
"request": "launch",
"name": "vuejs: chrome",
"url": "http://localhost:8080",
"webRoot": "${workspaceFolder}",
"breakOnLoad": true,
"pathMapping": {
"/_karma_webpack_": "${workspaceFolder}"
},
"sourceMapPathOverrides": {
"webpack:/*": "${webRoot}/*",
"/./*": "${webRoot}/*",
"/src/*": "${webRoot}/*",
"/*": "*",
"/./~/*": "${webRoot}/node_modules/*"
},
"preLaunchTask": "serve"
}
]
}
复制代码
添加任务脚本
{
"version": "2.0.0",
"tasks": [
{
"label": "serve",
"type": "npm",
"script": "serve",
"isBackground": true,
"problemMatcher": [
{
"base": "$tsc-watch",
"background": {
"activeOnStart": true,
"beginsPattern": "Starting development server",
"endsPattern": "Compiled successfully"
}
}
],
"group": {
"kind": "build",
"isDefault": true
}
}
]
}
复制代码
该脚本的作用是运行npm run serve
编译命令。
按
F5
启动调试即可
注意:此方式的主要点在于launch.json
配置文件中,通过preLaunchTask
字段指定调试前先运行一个任务脚本,preLaunchTask
的值对应tasks.json
文件中的label
值。
更多详细内容,大家可以点击这里的参考文档[2]查阅。
借助vscode插件Debugger for Chrome在Chrome中调试
第一步还是初始化vue项目,添加
vue.config.js
文件配置,指定要生成sourceMaps资源
module.exports = {
configureWebpack: {
// 生成sourceMaps
devtool: "source-map"
}
};
复制代码
vscode中扩展中安装
Debugger for Chrome
插件,并确保没有禁用插件
data:image/s3,"s3://crabby-images/1e6eb/1e6eb4cdd09f148abb5527dfb81ef08927ec5218" alt="4f9a76b811e6b888d30855737049082f.png"
手动启动项目的运行, 此方式不需要配置
tasks.json
任务
# 终端执行命令,启动项目
npm run serve
复制代码
按
F5
启动调试即可
data:image/s3,"s3://crabby-images/445c3/445c35e1fd173704a90bb5aa1dd22ff73a3977c7" alt="d75b02018a38cac62b8f7ee477479f3b.png"
更多详细内容,请点击这里的参考文档[3]查阅。
借助vscode插件Debugger for Firfox
在Firefox中调试
和
Debugger for Chrome
基本一样,区别在于安装Debugger for Firfox
插件,并在launch.json配置中,增加调试Firefox的配置即可,配置如下
{
"version": "0.2.0",
"configurations": [
// 省略Chrome的配置...
// 下面添加的Firefox的配置
{
"type": "firefox",
"request": "launch",
"reAttach": true,
"name": "vuejs: firefox",
"url": "http://localhost:8080",
"webRoot": "${workspaceFolder}/src",
"pathMappings": [{ "url": "webpack:///src/", "path": "${webRoot}/" }]
}
]
}
复制代码
调试时选择对应的调试命令即可
data:image/s3,"s3://crabby-images/5f06a/5f06a5f7afb259f541b9080278a711a6e28876ab" alt="ce2d48d344df6955df9fd7af104ef184.png"
Firefox初始启动时不会触发调试,需要刷新一次
调试Electron项目
Electron很多人都使用过,主要用于开发跨平台的系统桌面应用。那么来看下vue-cli-electron-builder
创建的Electron
项目怎么调试。步骤如下:
在初始化项目后,首先修改
vue.config.js
文件配置,增加sourceMaps配置:
module.exports = {
configureWebpack: {
devtool: 'source-map'
}
}
复制代码
创建调试配置
.vscode/launch.json
{
"version": "0.2.0",
"configurations": [
{
"name": "Electron: Main",
"type": "node",
"request": "launch",
"protocol": "inspector",
"preLaunchTask": "bootstarp-service",
"runtimeExecutable": "${workspaceRoot}/node_modules/.bin/electron",
"windows": {
"runtimeExecutable": "${workspaceRoot}/node_modules/.bin/electron.cmd"
},
"args": ["--remote-debugging-port=9223", "./dist_electron"],
"outFiles": ["${workspaceFolder}/dist_electron/**/*.js"]
},
{
"name": "Electron: Renderer",
"type": "chrome",
"request": "attach",
"port": 9223,
"urlFilter": "http://localhost:*",
"timeout": 0,
"webRoot": "${workspaceFolder}/src",
"sourceMapPathOverrides": {
"webpack:///./src/*": "${webRoot}/*"
}
},
],
"compounds": [
{
"name": "Electron: All",
"configurations": ["Electron: Main", "Electron: Renderer"]
}
]
}
复制代码
此处配置了两个调试命令: Electron: Main
用于调试主进程,Electron: Renderer
用于调试渲染进程;compounds[].
选项用于定义复合调试选项; configurations
定义的复合命令是并行的; preLaunchTask
用于配置命令执行前先执行的任务脚本,其值对应tasks.json
中的label
字段; preLaunchTask
用在compounds
时,用于定义configurations
复合任务执行前先执行的脚本。
创建任务脚本
{
// See https://go.microsoft.com/fwlink/?LinkId=733558
// for the documentation about the tasks.json format
"version": "2.0.0",
"tasks": [
{
"label": "bootstarp-service",
"type": "process",
"command": "./node_modules/.bin/vue-cli-service",
"windows": {
"command": "./node_modules/.bin/vue-cli-service.cmd",
"options": {
"env": {
"VUE_APP_ENV": "dev",
"VUE_APP_TYPE": "local"
}
}
},
"isBackground": true,
"args": [
"electron:serve", "--debug"
],
"problemMatcher": {
"owner": "custom",
"pattern": {
"regexp": ""
},
"background": {
"beginsPattern": "Starting development server\\.\\.\\.",
"endsPattern": "Not launching electron as debug argument was passed\\."
}
}
}
]
}
复制代码
启动调试
在主进程相关代码上打上断点,然后启动调试主进程命令就可以调试主进程了
data:image/s3,"s3://crabby-images/8141c/8141c8f4b686d6bb0066c686fe3c8ffacf0da0c0" alt="a0f0a59494a3fd6b6a3b54050c62828f.png"
注意,这里的options
参数是根据实际的情况,自定义添加我们运行项目时所需要的参数,比如我这里因为启动项目的npm命令是:
"serve-local:dev": "cross-env VUE_APP_TYPE=local VUE_APP_ENV=dev vue-cli-service electron:serve"
复制代码
主进程调试成功
data:image/s3,"s3://crabby-images/23420/2342075b29906adeda27d4a1f23d18fddbc13d96" alt="62ee79018d367a673d04b495ae314e84.png"
开始调试渲染进程
切换到渲染进程的调试选项,在渲染进程的代码处打上断点,点击调试。注意,此时并不会有断点终端,需要ctrl+r
手动刷新软件进程才会看到渲染进程的断点。
data:image/s3,"s3://crabby-images/63a51/63a51ff4700458c8fb4e21111aa3b09af826f3bc" alt="9533b0312cf26dff85591f722e78a78f.png"
刷新渲染进程后的效果,如下图,已经进入了断点
data:image/s3,"s3://crabby-images/f8daf/f8daf19fd77688baa04249425809f2a19e8eb964" alt="2da15b98ba4671d42b8568bba284ae15.png"
另一种方式
同时开启渲染进程和主进程的调试,只需要切换到调试全部的选项即可。注意,此种方式因为compounds[].configurations
配置是并行执行的,并不一定能保证渲染进程调试一定能附加到主进程调试成功(估计是时机问题),有些时候会调试渲染进程不成功。所以,可以采取上面的方式进行调试。
data:image/s3,"s3://crabby-images/b398e/b398ec70532b4a72e61456195da55189b379120e" alt="4fb9155490f0f3b61fe2770447f91372.png"
更多调试Electron的内容,可以点击参考文档[4]查阅。
补充:更进一步
VS调试React app文档[5]
VS调试Next.js文档[6]
更多...[7]
其他技巧
技巧一:代码片段(snippets)
从扩展商店中安装snippets
@category:"snippets"
复制代码
data:image/s3,"s3://crabby-images/705b6/705b6532550250cc15b991259993fc9e50abe465" alt="bcae50c7955e457a19bbc210867034f3.png"
创建全局代码片段
选择
文件 -> 首选项 -> 用户片段
选择
新建全局代码片段文件
data:image/s3,"s3://crabby-images/f193a/f193a5aa630d21c86dd7afd3410d239b99b1386a" alt="63e046c943eb150e017ef4a59f0e2d30.png"
添加代码片段文件的文件名称,会生成
.code-snippets
后缀的文件定义用户片段
{
"自动补全console.log": {
"scope": "javascript,typescript",
"prefix": "log",
"body": [
"console.log('$1');",
"$2"
],
"description": "输出console.log('')"
}
}
复制代码
关键词 | 类型 | 说明 |
---|---|---|
scope | string | 代码片段生效的作用域,可以是多个语言,比如javascript,typescript 表示在js和ts生效,不加scope 字段表示对所有文件类型生效 |
prefix | `string | string[]` |
body | string[] | 代码片段内容,数组的每一项会是一行 |
description | string | IntelliSense 显示的片段的可选描述 |
1−1 - 1−n | - | 定义光标的位置,光标根据数字大小按tab依次跳转;注意$0 是特殊值,表示光标退出的位置,是最后的光标位置。 |
在键盘输入
log
时效果如下
data:image/s3,"s3://crabby-images/56af1/56af1b99e389f2a89564c18afc2b8af7f5e24dc0" alt="af784d3609f3f8a47c26a31d1baae589.png"
指定光标处的默认值并选中
"body": [
"console.log('${1:abc}');"
],
复制代码
data:image/s3,"s3://crabby-images/6cd30/6cd303853a68371d701f6b519372b6f1a5605e3e" alt="931e9e13bf9f886bafb9d902fcec3e75.png"
指定光标处的默认值有多个,并提供下拉选择
用两个竖线包含多个选择值,|多个选择值直接用逗号隔开|
"body": [
"console.log('${1:abc}');",
"${2|aaa,bbb,ccc|}"
],
复制代码
data:image/s3,"s3://crabby-images/a04f7/a04f7e11d6f1ce0af39869765b6b79ba8b6d88bc" alt="2bd8a189652c250b15971ec146a9a8ba.png"
新建当前工作区的代码片段
只需要选择文件 \-> 首选项 \-> 用户片段 \-> 新建xxx文件夹的代码片段
, 新建后会在当前工作区生成.vscode/xxx.code-snippets
文件
data:image/s3,"s3://crabby-images/bb979/bb979544b59a5788a83095026922e35462ea354a" alt="c80c4cf29e13d63003c7f2adbfcdbb59.png"
技巧二:Emmet
vscode内置了对Emmet的支持,无需额外扩展。例如html的Emmet演示如下:
data:image/s3,"s3://crabby-images/8328f/8328f75a241f4eea25db8ee1d8874a605210ea2f" alt="b40af9c32e7c397f4893917e03436d9d.png"
技巧三:对光标处代码变量快速重命名
选中或者光标所处的位置,按F2
可以对所有的变量重命名
data:image/s3,"s3://crabby-images/0fa1f/0fa1fbbb2bae597838a78acb7554bd2692bbafd2" alt="34eba374aa6589d23745ca23f77ca66a.png"
技巧四:代码重构建议
选中要重构的代码,点击出现的黄色小灯的图标
data:image/s3,"s3://crabby-images/9091d/9091d71a48a040b295449a53b39ea10ca8ebdcbe" alt="f3b10150798083b34747b8ceb6eefa9f.png"
选中重构的类型
data:image/s3,"s3://crabby-images/0bcb5/0bcb5a40842b2fa961cd00d33926581b68b1779f" alt="6ff4756054d4f6c2c87eb1e801f13fec.png"
输入新的变量名
data:image/s3,"s3://crabby-images/6a098/6a098149da75dab4e6d0559c97fca5e7b1fd73be" alt="7c8d71f1a3c46e55d3b485ab6918a4c7.png"
还可以重构到函数
data:image/s3,"s3://crabby-images/9ec96/9ec9677d400bc4cf53ee6f56ed6eaece95119e23" alt="22315bf32da5201f1a0286ae5b105974.png"
TS中还可以提取接口等等
data:image/s3,"s3://crabby-images/05189/0518924bec30d575e9f6caade95da1f52e9517a0" alt="95e74aa174dff2028dba03dab0c194e0.png"
补充:VsCode扩展插件开发
VsCode扩展插件可以做什么事情?
定制主题、文件图标
扩展工作台功能
创建webView
自定义新的语言提示
支持调试特定的runtime
基于Yeoman
快速开发VsCode插件,步骤如下:
安装
Yeoman
和用于生成模板的插件VS Code Extension Generator[8]
# 终端运行,主要node版本需要12及以上,node10会安装报错
npm i -g yo generator-code
复制代码
运行
yo code
创建命令,选择要生成的项目模板。这里演示New extension
data:image/s3,"s3://crabby-images/0bae9/0bae907a026fd0d2bd3dc07a5b5e0f7b93200799" alt="30f3bf846ff51c0c9364e4bcbc234cfc.png"
根据提示依次选择
data:image/s3,"s3://crabby-images/59016/59016cbfecc706c49daafd275ea85459000b1732" alt="54cd1defcc4810d9cb465af57daa038d.png"
生成的内容如下
data:image/s3,"s3://crabby-images/7132e/7132e94686f25e36d3fafb4a6d1a3dd695e17665" alt="efa30c1c701101be7bf705e66cb3196b.png"
按
F5
生成编译项目,此时会自动打开一个新窗口在新窗口按
Ctrl+Shfit+P
,输入Hello World
命令
data:image/s3,"s3://crabby-images/4a1ec/4a1ec5850cfe360675ad211ddc6c83e74ce34b82" alt="c126c307a507fa08c80708869752976b.png"
此时会弹出一个弹窗的效果
data:image/s3,"s3://crabby-images/51242/51242eae257609e9ca197f581d60c1b4526de32f" alt="fd5f50e2368b8277d3ce202e20ee1508.png"
至此,一个最简单的插件就完成了
结束语
我是你们的老朋友愣锤,小伙伴们如果喜欢上面的内容,欢迎点赞收藏以供后续学习。转载注明作者: 愣锤。
同时推荐如下内容阅读:
awesome-canvas[9] - 中文版Canvas资源大全,目前收录了几百个好玩又有用的Canvas库。欢迎star哈~ Github地址 github.com/chinaBerg/a…[10]
Ts高手篇:22个示例深入讲解Ts最晦涩难懂的高级类型工具[11]juejin.cn/post/699410…[12]
血荐28个让你直呼哇塞的Canvas库[13]juejin.cn/post/703826…[14]
关于本文
来源:愣锤
https://juejin.cn/post/7071146744339234846
最后
欢迎关注【前端瓶子君】✿✿ヽ(°▽°)ノ✿
回复「算法」,加入前端编程源码算法群,每日一道面试题(工作日),第二天瓶子君都会很认真的解答哟!
回复「交流」,吹吹水、聊聊技术、吐吐槽!
回复「阅读」,每日刷刷高质量好文!
如果这篇文章对你有帮助,「在看」是最大的支持
》》面试官也在看的算法资料《《
“在看和转发”就是最大的支持