- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
最新的 angular2 npm 包似乎无法调试 typescript 源代码。现有answer on stackoverflow和 the article on medium已经过时了。我创建了 a github issue ,请多多支持。
有两个问题:
1) TypeScript 源不再被硬编码为源映射中的数据 URI,但实际上指向 npm 中一些不存在的位置(它实际上是 angular git hub 源中的一个位置,但不是 npm 包中的东西):
{
"version":3,
"file":"application_ref.js",
"sourceRoot":"",
"sources":["../../../../modules/@angular/core/src/application_ref.ts"] <-------
我已经追踪到这条路径没有相关性,因为 Angular 源是使用 --inlineSources
编译的选项等等 *.map
文件包含 sourcesContent
里面有原始内容的 key 。所以这不再是问题了。但第二个问题仍然存在。
2) 即使我简单地复制 modules
来自 github 源的文件夹,还有第二个问题,即 js
npm 包中的文件被编译成 es6
模块语法,浏览器尚不支持,加载器(如 SystemJS)需要 traceur。例如,common/index.j
:
export { NgLocalization, CommonModule, NgClass, NgFor, NgIf, NgPlural, NgPluralCase, NgStyle, NgSwitch, NgSwitchCase, NgSwitchDefault, NgTemplateOutlet, AsyncPipe, DatePipe, I18nPluralPipe, I18nSelectPipe, JsonPipe, LowerCasePipe, CurrencyPipe, DecimalPipe, PercentPipe, SlicePipe, UpperCasePipe, VERSION, Version, PlatformLocation, LocationStrategy, APP_BASE_HREF, HashLocationStrategy, PathLocationStrategy, Location } from './src/common';
但我不能使用traceur
,因为它很可能会破坏为 js
创建的现有源映射由 tsc
转译的文件.
最佳答案
UPD 我打开了issue要求在 Angular CLI 中启用源映射支持。它还讨论了如何在今天启用源 map 支持。为框架启用源映射将实质上允许调试 TypeScript 源。
Angular CLI 从使用 System.js 切换到 Webpack,我个人不喜欢 System.js,所以这里没有关于 System.js 的答案。
您无法针对框架本身的 TypeScript 源代码进行调试,因为源映射是为已编译的 JavaScript 而不是 TypeScript 生成的。另一方面,生成的代码易于阅读,并且足以用于调试目的。好消息是您自己的代码将源映射到原始 TypeScript 源。
而且我认为没有一种简单的方法可以获取 Angular 与 TypeScript 源的源映射,除非它们与框架一起构建。所以你现在最好的办法就是调试编译后的 JS。
现在开始练习。使用 Angular CLI 创建新应用:
$ ng new my-app
在某处添加断点:
// src/app/app.component.ts
export class AppComponent {
title = 'app works!';
constructor() {
debugger;
}
}
启动开发服务器:
$ ng serve
然后在浏览器中打开以下 URL:http://localhost:4200/ .观察它在断点处停止并转到堆栈中的一些框架调用。
关于angular - 如何调试 angular2 typescript 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41651866/
昨晚我因为这个问题脑子崩溃了。在确保没有来 self 的 eclipse 错误检查的明显错误之后,我开始调试我的程序。顺便说一下,我正在使用 Jre7。无论如何,每次我进入我的类调用(我们称之为“a”
(前言:我对 C/C++ 还很陌生,我真的不知道 native 代码中的调试实际上是如何工作的。) 一些消息来源说 gdb 和 lldb 可以调试 any program compiled to ma
我正在尝试从 Visual Studio 2012 外部调试 T4Scaffolding.Core Nuget 包。我使用的是安装了 Powershell 3.0 的 Powershell ISE,并
如何调试汇编代码?我在 Linux 上使用 gdb。我知道我可以看寄存器。有哪些调试汇编代码的方法? 最佳答案 您当然可以使用 breakpoints就像 C 或任何其他编译语言一样。 This ar
如何在每次通话时打印列表或 haskell 中的内容,例如: funct a list = funct (a + 1) (a : list) print list her
让我用我对 Makefiles 或 make 知之甚少的评论作为这个问题的前缀。 有一个非常大的项目,每晚自动构建。它以 Debug 和 Release 模式构建,Debug 用于 Valgrind
我正在创建一个计算每周工资的程序,那么任何加类工资都是该周正常工资的 1.5 倍。我的代码如下: #include int main() { double payrate; double h
我使用的是 Visual Studio 2010 Express Developer 版本。开发网站。我在我的 .aspx 页面中使用 JavaScript。 如何在 Javascript 中放置断点
我最近开始修补 Project Euler 问题,并尝试用 Javascript 解决它们。这样做我往往会产生许多无限循环,现在我想知道是否有比终止 Firefox 或 Chrome 中的选项卡更好的
有没有办法在程序执行期间生成一个交互式 python 控制台(最好是 iPython)而不暂停主程序并且能够检查和修改程序变量?类似于浏览器为 JavaScript 提供的功能。 我知道 pdb.se
我正在使用 FFmpeg @ Android 并希望能够进入 FFmpeg 代码(Eclipse + Seqouya),同时编译 FFmpeg 我使用 --disable-stripping --en
我从使用互操作调用 win32 api 函数的 .net 进程中得到一个异常。 我有一个调试器,我想查看 LastError 的值。 是否可以从 Visual Studio 调试器中查看 LastEr
我正在尝试通过 VBA 创建一个宏,以在 IE 的多个选项卡中打开一组指定的链接。目前我正在使用下面的代码,如果我试图打开 3 个或更少的选项卡,它大部分时间都可以工作。任何超过 3 的代码都会在“N
好的,这似乎是一个愚蠢的问题,因为 MonoDevelop 越来越成熟,所以我确定我只是想念它,但我环顾四周,所有关于这个主题的问题似乎都是关于远程调试或 Mac 上的调试。 我使用的是 Ubuntu
如何调试 Rscripts是从命令行运行的? 我目前正在使用 getopt传递命令行选项的包,当有错误时,我很难: 看看到底出了什么问题; 在 R 中交互式调试(因为脚本需要命令行选项。) 有没有人有
支持 PDF 和网络上的信息很少。我碰巧在博客中看到一篇文章,提到 $.write() 或 $.writeln() 将向 javascript 控制台写入一个字符串。相当有用。有谁知道这个 $ 对象是
PyCharm 1.5 中是否可以使用 Firefox 和 Chrome 支持的 JavaScript 调试? 如果是这样,它能否与 Python/Django 调试器一起有效运行? 如果没有,有没有
我确定这以前发生在人们身上,某些东西在 Debug模式下工作,你在发布时编译,但有些东西坏了。 这发生在我在嵌入式 XP 环境中工作时,我发现最好的方法确实是编写一个日志文件来确定它会出错的地方。 您
我目前正在为即将到来的项目评估 Flow3。 AOP 模式和依赖注入(inject)将非常适合我们的目的。 现在我想不通的是如何在 Controller Action 中调试一些结果。 public
最初,我有一个包含测试服务器的 Django 应用程序。要调试此设置,我只需添加 import pdb; pdb.set_trace()代码中的任何位置,并且有一个断点将我扔到终端中的交互式调试器中(
我是一名优秀的程序员,十分优秀!