我有一个由ng cli生成的角度2应用程序。
- 当我运行build(或)ng build --prod --aot = false并提供页面时,一切正常。
- 但是当我尝试通过运行ng serve --aot = true并提供服务来启用aot时,该页面会出现多个DI错误,如下所示很难调试。关于如何调试这些问题的任何想法?
例外:没有选项提供者!
error_handler.js:59 ORIGINAL STACKTRACE:
ErrorHandler.handleError @ error_handler.js:59
(匿名)@ application_ref.js:272
webpackJsonp.679.ZoneDelegate.invoke @ zone.js:229
onInvoke @ ng_zone.js:271
webpackJsonp.679.ZoneDelegate.invoke @ zone.js:228
webpackJsonp.679.Zone.run @ zone.js:113
(匿名)@ zone.js:509
webpackJsonp.679.ZoneDelegate.invokeTask @ zone.js:262
onInvokeTask @ ng_zone.js:262
webpackJsonp.679.ZoneDelegate.invokeTask @ zone.js:261
webpackJsonp.679.Zone.runTask @ zone.js:151
drainMicroTaskQueue @ zone.js:405
答案 0 :(得分:15)
您是否有机会使用: angular2-logger ?我有完全相同的错误,并发现即使我实际上没有使用我必须提供的选项 - 很多工作。
例如:在你的AppModule中必须跟随导入:
import {Logger, Options} from "angular2-logger/core";
然后在您的提供商列表中确保添加选项:
providers: [
Logger,
Options // <-- this is key
]
这确保AOT包含“选项”。
现在,我是怎么知道的?该错误为您提供了无法找到“选项”的提示。所以我使用Developer Tools来查看使用sourceMaps生成的源代码(我查看了main.bundle.js)。在那里,我搜索了字符串“选项”,唯一的命中也给了我最后的提示:
__WEBPACK_IMPORTED_MODULE_9_angular2_logger_core__["Options"])
现在,在查看了我必须提供选项的文档后,我意识到了这一点。
希望这会有所帮助。 :)