【问题标题】:Visual Studio 2019 (not VS Code) typescript debugging breakpoint unboundVisual Studio 2019(不是 VS Code)打字稿调试断点未绑定
【发布时间】:2021-09-12 07:15:40
【问题描述】:

我错过了什么.....

我使用 Visual Studio 2019 在 .Net 5 项目中托管了一个 Angular 12 项目(这是一个较旧的应用程序,我正在尝试快速升级版本 - 我知道这可能不是理想的设置)。

我正在尝试通过在 Visual Studio 中设置断点来调试我的 Angular(打字稿)组件,但我遇到了“断点未绑定”问题并且它没有被命中。我了解关于将打字稿文件转换为用于托管的 javascript 文件的工作原理,但是,我曾经能够在我的打字稿文件中的 Visual Studio 中设置一个断点,并且它会毫无问题地被击中(带有 .Net2.2 的 Angular 5 )。

我已经用谷歌搜索了很长时间,但似乎无法准确找到我需要做的事情 - 可能是 tsconfig.json 设置,或者可能是我正在使用我的“ng build”命令进行生产构建角度应用程序,或者我没有正确的开发设置(我不确定)。

我找到了一些关于如何使用浏览器调试代码的说明,但这并不理想 - 这有点违背了使用优质 IDE 的目的之一。

提前感谢你能给我的任何帮助 - 我要疯了!

我的 tsconfig 文件内容是:

{
  "compileOnSave": false,
  "compilerOptions": {
    "baseUrl": "./",
    "outDir": "./dist/out-tsc",
    "forceConsistentCasingInFileNames": true,
    "strict": true,
    "noImplicitReturns": true,
    "noFallthroughCasesInSwitch": true,
    "sourceMap": true,
    "declaration": false,
    "downlevelIteration": true,
    "experimentalDecorators": true,
    "moduleResolution": "node",
    "importHelpers": true,
    "target": "es2017",
    "module": "es2020",
    "lib": [
      "es2018",
      "dom"
    ]
  },
  "angularCompilerOptions": {
    "enableI18nLegacyMessageIdFormat": false,
    "strictInjectionParameters": true,
    "strictInputAccessModifiers": true,
    "strictTemplates": true
  }
}

我的 tsconfig.app.json 文件内容是:

{
  "extends": "./tsconfig.json",
  "compilerOptions": {
    "outDir": "./out-tsc/app",
    "types": []
  },
  "files": [
    "src/main.ts",
    "src/polyfills.ts"
  ],
  "include": [
    "src/**/*.d.ts"
  ]
}

我的 angular.json 文件设置是:

{
  "$schema": "./node_modules/@angular/cli/lib/config/schema.json",
  "version": 1,
  "newProjectRoot": "projects",
  "projects": {
    "client": {
      "projectType": "application",
      "schematics": {
        "@schematics/angular:component": {
          "inlineTemplate": true,
          "inlineStyle": true,
          "skipTests": true
        },
        "@schematics/angular:class": {
          "skipTests": true
        },
        "@schematics/angular:directive": {
          "skipTests": true
        },
        "@schematics/angular:guard": {
          "skipTests": true
        },
        "@schematics/angular:interceptor": {
          "skipTests": true
        },
        "@schematics/angular:pipe": {
          "skipTests": true
        },
        "@schematics/angular:service": {
          "skipTests": true
        },
        "@schematics/angular:application": {
          "strict": true
        }
      },
      "root": "",
      "sourceRoot": "src",
      "prefix": "app",
      "architect": {
        "build": {
          "builder": "@angular-devkit/build-angular:browser",
          "options": {
            "outputPath": "../wwwroot/client",
            "index": "src/index.html",
            "main": "src/main.ts",
            "polyfills": "src/polyfills.ts",
            "tsConfig": "tsconfig.app.json",
            "assets": [
              "src/favicon.ico",
              "src/assets"
            ],
            "styles": [
              "src/styles.css"
            ],
            "scripts": []
          },
          "configurations": {
            "production": {
              "budgets": [
                {
                  "type": "initial",
                  "maximumWarning": "500kb",
                  "maximumError": "1mb"
                },
                {
                  "type": "anyComponentStyle",
                  "maximumWarning": "2kb",
                  "maximumError": "4kb"
                }
              ],
              "fileReplacements": [
                {
                  "replace": "src/environments/environment.ts",
                  "with": "src/environments/environment.prod.ts"
                }
              ],
              "outputHashing": "none"
            },
            "development": {
              "buildOptimizer": false,
              "optimization": false,
              "vendorChunk": true,
              "extractLicenses": false,
              "sourceMap": true,
              "namedChunks": true
            }
          },
          "defaultConfiguration": "production"
        },
        "serve": {
          "builder": "@angular-devkit/build-angular:dev-server",
          "configurations": {
            "production": {
              "browserTarget": "client:build:production"
            },
            "development": {
              "browserTarget": "client:build:development"
            }
          },
          "defaultConfiguration": "development"
        },
        "extract-i18n": {
          "builder": "@angular-devkit/build-angular:extract-i18n",
          "options": {
            "browserTarget": "client:build"
          }
        }
      }
    }
  },
  "defaultProject": "client"
}

【问题讨论】:

    标签: typescript debugging visual-studio-2019 breakpoints visual-studio-debugging


    【解决方案1】:

    试试这些,看看其中一个是否有效。

    1)。转到工具 > 选项 > 调试 > 常规 > 选中“为 ASP .NET(Chrome、Edge 和 IE)启用 JavaScript 调试”复选框。 (不知道这是否有效,你可以试试)

    2)。确保您在调试时选择了“调试”模式/配置而不是“发布”。

    3)。转到您的解决方案/项目文件夹并删除.vsbinobj 文件夹(您可以进行备份),然后重新构建您的项目/解决方案并对其进行调试。

    4)。尝试重新启动 Visual Studio,并重置断点。

    【讨论】:

    • 感谢您的回答天宇 - 不幸的是它没有工作。我认为您应该能够在 Angular 应用程序中的 Visual Studio 中的打字稿文件中设置断点并在调试模式下在浏览器中运行它时停止是正确的?我曾经在 Internet Explorer 11 上这样做过。还有其他人有什么建议或者可以在我的 tsconfig 文件中找到问题吗?
    • 是的,VS 打断点(在 TS 中)并停在我这边。但我等了一分钟,或者可能是 30 秒,或者两分钟,我不记得了。在调试过程加载良好之前,我可以看到断点警告类似于“断点已设置但未绑定”,我只是等待它然后工作。
    • 嗯,即使在 Visual Studio 修复之后,我仍然无法正常工作。我什至用 Visual Studio Mac 尝试过,但没有任何乐趣。我想知道您是否介意使用我上传到 GitHub (github.com/rasaconsulting-sandy/TestAngularTypescriptDebugging) 的测试解决方案来获得断点。我怀疑我的 tsconfig / angular.json 设置不正确,但不知道是哪一个。我无法在这个简单的标准 ASP.Net Core Web 应用程序和标准 Angular 应用程序中找到断点。如果您不介意这样做,请提前致谢。
    • 注意:在 Visual Studio 中运行之前,该解决方案需要在“client”文件夹中进行“nom install”和“ng build”。
    • 嗨桑迪,我测试了你的样本,断点也没有在我这边命中。我可以确认新创建的简单的 Asp .Net Core 项目(带有 Angular)在 VS 2019 中可以成功打断点。我检查了 tsconfig.json 文件、angular.json 文件和其他文件,并匹配它们,做了一些修改,但我没有找到或成功更改它们以使断点工作。我觉得这应该和这个项目的设置有关,或者是相关工具的版本有关,但需要多查。
    猜你喜欢
    • 1970-01-01
    • 2021-10-05
    • 2018-02-20
    • 2022-12-23
    • 2018-09-08
    • 2020-12-06
    • 2021-09-12
    • 1970-01-01
    • 2020-09-21
    相关资源
    最近更新 更多