利用vscode調(diào)試編譯后的js代碼詳解
前言
在開發(fā)的過程中,幾乎不可能一次性就能寫出毫無破綻的程序,斷點(diǎn)調(diào)試代碼是一個(gè)普遍的需求。
vscode 是一個(gè)非常棒的編輯器,內(nèi)置功能強(qiáng)大的調(diào)試能力。經(jīng)過簡(jiǎn)單的設(shè)定,就可以對(duì) js 文件進(jìn)行調(diào)試。但有時(shí)我們想要調(diào)試的內(nèi)容是經(jīng)過編譯的,當(dāng)然我們可以直接調(diào)試編譯后的代碼。但經(jīng)過編譯壓縮以后的代碼,可讀性很差,且也可能無法分模塊查看了,有什么方法進(jìn)行編譯前的代碼調(diào)試么?答案當(dāng)然是肯定的。
下面話不多說了,來一起看看詳細(xì)的介紹吧。
vscode 的常規(guī)調(diào)試
vscode 的調(diào)試界面在窗口最左邊:

最新版本的vscode,該選項(xiàng)默認(rèn)隱藏了,需要自己打開。
首次打開調(diào)試界面時(shí),當(dāng)前沒有任何調(diào)試配置,我們可以點(diǎn)擊齒輪 icon 添加一個(gè):

選擇 nodejs 后,會(huì)自動(dòng)在當(dāng)前工程目錄下添加 .vscode/launch.json 文件,這個(gè)文件就是 vscode 調(diào)試配置文件。
一個(gè)簡(jiǎn)易的配置文件內(nèi)容為:
{
// 使用 IntelliSense 了解相關(guān)屬性。
// 懸停以查看現(xiàn)有屬性的描述。
// 欲了解更多信息,請(qǐng)?jiān)L問: https://go.microsoft.com/fwlink/?linkid=830387
"version": "0.2.0",
"configurations": [
{
"type": "node",
"request": "launch",
"name": "啟動(dòng)程序",
"program": "${workspaceFolder}/index.js"
}
]
}
上面這個(gè)配置所做的工作是啟動(dòng)當(dāng)前目錄下的 index.js 文件進(jìn)行調(diào)試。
我們也可以設(shè)置每次摁 F5 時(shí)自動(dòng)調(diào)試當(dāng)前打開的文件,只需要修改 program:
{
"program": "${file}"
}
調(diào)試編譯后的文件
想要調(diào)試編譯后的文件,需要對(duì) launch.json 文件進(jìn)行設(shè)置。
vscode 要想調(diào)試編譯后的代碼,他需要知道哪些代碼是經(jīng)過編譯的,且需要知道編譯后的代碼與編譯前代碼的對(duì)應(yīng)關(guān)系。
其實(shí)理論上 vscode 是可以把每個(gè)要執(zhí)行的文件都認(rèn)為是編譯后的文件,進(jìn)行源文件的查找?我猜是因?yàn)樾阅茉颍覀冃枰约褐付男┪募蔷幾g后的文件。在 launch.json 中,使用outFiles屬性來指定編譯后的產(chǎn)出文件:
{
"version": "0.2.0",
"configurations": [
{
// 省略其他設(shè)置...
"outFiles": [
"${workspaceFolder}/lib/*.js",
]
// ...
}
]
}
雖然有些麻煩,但好在我們可以使用通配符。
現(xiàn)在有了編譯后的文件,vscode 還需要知道源文件,以及編譯后文件與源文件的對(duì)應(yīng)關(guān)系,聽著有沒有很熟悉?這個(gè)過程就是通過 sourcemap 來進(jìn)行實(shí)現(xiàn)的。
我們需要在編譯 js 文件時(shí)生成相應(yīng)的 .map 文件,并在產(chǎn)出 js 文件后面附加 .map 文件的地址:
//@ sourceMappingURL=./index.js.map
ok,現(xiàn)在 vscode 在執(zhí)行 js 文件時(shí),會(huì)從 outFile 中查找是否是編譯后的代碼,如果是,就通過 sourcemap 映射到源代碼,方便我們進(jìn)行調(diào)試。
自動(dòng)執(zhí)行編譯
現(xiàn)在我們的開發(fā)流程變成了:修改源代碼 -> 編譯源代碼 -> 調(diào)試。
為了方便,我們可以設(shè)置preLaunchTask屬性,該屬性的作用是每次調(diào)試前執(zhí)行一個(gè)前置任務(wù),我們可以把編譯過程放在前置任務(wù)里。
首先我們需要來配置一個(gè)task,task的配置文件在 .vscode/tasks.json,可以打開 command palette (⇧⌘P (Windows, Linux Ctrl+Shift+P)) 選擇“任務(wù):配置任務(wù)”自動(dòng)生成一個(gè):
{
// 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作為前置任務(wù),每次執(zhí)行調(diào)試時(shí)都會(huì)先進(jìn)行 build。
示例配置文件
{
// 使用 IntelliSense 了解相關(guān)屬性。
// 懸停以查看現(xiàn)有屬性的描述。
// 欲了解更多信息,請(qǐng)?jiān)L問: 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"
]
}
相關(guān)文檔
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
基于Bootstrap 3 JQuery及RegExp的表單驗(yàn)證功能
這篇文章主要介紹了基于Bootstrap 3 JQuery及RegExp的表單驗(yàn)證功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02
網(wǎng)頁前端登錄js按Enter回車鍵實(shí)現(xiàn)登陸的兩種方法
下面小編就為大家?guī)硪黄W(wǎng)頁前端登錄js按Enter回車鍵實(shí)現(xiàn)登陸的兩種方法。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考2016-05-05
JavaScript易錯(cuò)知識(shí)點(diǎn)整理
本文主要對(duì)JavaScript易錯(cuò)知識(shí)點(diǎn)進(jìn)行整理和匯總。需要的朋友可以看下,希望對(duì)大家有所幫助2016-12-12
JavaScript實(shí)現(xiàn)模仿桌面窗口的方法
這篇文章主要介紹了JavaScript實(shí)現(xiàn)模仿桌面窗口的方法,可實(shí)現(xiàn)模仿桌面窗口的打開、關(guān)閉、移動(dòng)、縮放及最大化、最小化等功能,需要的朋友可以參考下2015-07-07
javascript getElementByTagName的使用
javascript getElementByTagName當(dāng)鼠標(biāo)放上去時(shí)將超鏈接的顏色設(shè)為藍(lán)色的。2009-06-06

