中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何利用vscode調試編譯后的js代碼

發布時間:2021-02-22 12:32:20 來源:億速云 閱讀:247 作者:清風 欄目:web開發

這篇“如何利用vscode調試編譯后的js代碼”文章,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要參考一下,對于“如何利用vscode調試編譯后的js代碼”,小編整理了以下知識點,請大家跟著小編的步伐一步一步的慢慢理解,接下來就讓我們進入主題吧。

vscode有什么用

Visual Studio Code 是一個運行于 OS X,Windows和 Linux 之上的,針對于編寫現代 web 和云應用的跨平臺編輯器,它為開發者們提供了對多種編程語言的內置支持,并且正如 Microsoft 在Build 大會的 keynote 中所指出的,這款編輯器也會為這些語言都提供了豐富的代碼補全和導航功能。

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"
 ]
 }

以上是“如何利用vscode調試編譯后的js代碼”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

阳新县| 惠州市| 治县。| 桂东县| 满洲里市| 皋兰县| 新巴尔虎右旗| 阿克苏市| 信丰县| 青川县| 时尚| 平遥县| 五台县| 叙永县| 延吉市| 崇文区| 会同县| 读书| 育儿| 弋阳县| 紫云| 苏尼特左旗| 沐川县| 广东省| 荥经县| 通山县| 响水县| 正定县| 宕昌县| 许昌市| 昌图县| 高碑店市| 聂拉木县| 高青县| 任丘市| 楚雄市| 清河县| 靖边县| 遂昌县| 澎湖县| 印江|