Heim > Fragen und Antworten > Hauptteil
Ich versuche, VueJS mit vscode zu debuggen. Ich habe viele Tutorials/Antworten ausprobiert, bekomme es aber nicht zum Laufen.
Deshalb habe ich beschlossen, hier eine Frage zu stellen: Vielleicht gibt es jetzt einen richtigen Weg, es zum Laufen zu bringen.
Ich habe ein Projekt erstellt, das mit dem identisch ist, das ich debuggen möchte, damit ich den Ausdruck hier posten kann.
Die Projektstruktur ist:
Dies ist der ungebundene Haltepunkt:
/** * @type {import('@vue/cli-service').ProjectOptions} */ module.exports = { configureWebpack: { devtool: "source-map" }, transpileDependencies: true }
{ "version": "0.2.0", "configurations": [ { "type": "chrome", "request": "launch", "name": "vuejs: chrome", "url": "http://localhost:8080", "webRoot": "${workspaceFolder}", "sourceMapPathOverrides": { "**/src/*": "${webRoot}/src/*", }, "preLaunchTask": "vuejs: start" } ] }
{ "version": "2.0.0", "tasks": [ { "label": "vuejs: start", "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 } } ] }
{ "name": "test", "version": "0.1.0", "private": true, "scripts": { "serve": "vue-cli-service serve", "build": "vue-cli-service build", "lint": "vue-cli-service lint" }, "dependencies": { "core-js": "^3.8.3", "vue": "^2.6.14" }, "devDependencies": { "@babel/core": "^7.12.16", "@babel/eslint-parser": "^7.12.16", "@vue/cli-plugin-babel": "~5.0.0", "@vue/cli-plugin-eslint": "~5.0.0", "@vue/cli-service": "~5.0.0", "eslint": "^7.32.0", "eslint-plugin-vue": "^8.0.3", "vue-template-compiler": "^2.6.14" }, "eslintConfig": { "root": true, "env": { "node": true }, "extends": [ "plugin:vue/essential", "eslint:recommended" ], "parserOptions": { "parser": "@babel/eslint-parser" }, "rules": {} }, "browserslist": [ "> 1%", "last 2 versions", "not dead" ] }
Aktualisiert
@A.D hat mich gefragt, ob ich versucht habe, Schlüsselwörter zu verwenden
debugger;
Die Ergebnisse sind wie folgt: Ps: Ich möchte nicht anfangen, einen Debugger in meinen Code zu schreiben...
Aber ich kann sehen, dass die Debugger-Datei auf Folgendes verweist:
C:UsersvinicDesktoptesttestjswebpack:testsrccomponentsHelloWorld.vue
Aber die Komponente src befindet sich tatsächlich
C:UsersvinicDesktoptesttestsrccomponentsHelloWorld.vue
Warum haben meine Haltepunkte keine Grenzen?
P粉6484692852023-11-03 13:25:02
尝试更改 webRoot 参数并保留文档中的内容,您需要在 ${workspaceFolder} 之后包含 src。
{ "type": "chrome", "request": "launch", "name": "vuejs: chrome", "url": "http://localhost:8080", "webRoot": "${workspaceFolder}/src", "breakOnLoad": true, "sourceMapPathOverrides": { "webpack:///src/*": "${webRoot}/*" } }
更新: 经过一番研究,我发现了这个问题。 您使用的这个版本有一个变化。 他们更改了编译器,这影响了调试器的方式。
您可以使用此版本中的“2.6.11”作品。
注意:此更改影响后续版本。
P粉4474950692023-11-03 09:33:04
貌似vue 2.6.11以上版本的webpack存在一些问题
与 @Tonielton Mota 进行一些讨论后,我注意到,如果我从 package.json 和 package-lock.json 中完全删除属性名称,它就可以工作。
以下是正在运行的文件:
{ // Use IntelliSense to learn about possible attributes. // Hover to view descriptions of existing attributes. // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 "version": "0.2.0", "configurations": [ { "type": "chrome", "request": "launch", "name": "vuejs: chrome", "url": "http://localhost:8080", "webRoot": "${workspaceFolder}/src", "sourceMapPathOverrides": { "webpack:///src/*": "${webRoot}/*", }, "preLaunchTask": "vuejs: start" } ] }
{ "version": "0.1.0", "private": true, "scripts": { "serve": "vue-cli-service serve", "build": "vue-cli-service build", "lint": "vue-cli-service lint" }, "dependencies": { "core-js": "^3.8.3", "vue": "^2.6.14" }, "devDependencies": { "@babel/core": "^7.12.16", "@babel/eslint-parser": "^7.12.16", "@vue/cli-plugin-babel": "~5.0.0", "@vue/cli-plugin-eslint": "~5.0.0", "@vue/cli-service": "~5.0.0", "eslint": "^7.32.0", "eslint-plugin-vue": "^8.0.3", "vue-template-compiler": "^2.6.14" }, "eslintConfig": { "root": true, "env": { "node": true }, "extends": [ "plugin:vue/essential", "eslint:recommended" ], "parserOptions": { "parser": "@babel/eslint-parser" }, "rules": {} }, "browserslist": [ "> 1%", "last 2 versions", "not dead" ] }