2

过去一天我一直在为此挠头。我在我的角度应用程序中使用 Ngx-Toastr 包。以下是我认为可以帮助您理解问题的要点。

  1. 在开发服务器(ng serve)中,我没有收到任何错误,没有 Nullinjector 问题,然后我使用以下命令(ng build)进行了生产构建。到此为止,一切正常。现在我需要优化包大小,所以我运行了这个(ng build --prod)。构建成功没有错误现在是时候提供代码了(我正在使用节点服务器来提供这个)。问题从这里开始——

  2. 首先它要求

'NullInjectorError: ToastrService 没有提供者'

它来自 Ngx-Toastr 包它自己,它是有道理的,所以我将该服务添加到 appmodules 以及提供程序数组中的其他延迟加载的模块中。所以在此之后错误消失了。但接下来是我要说的——

  1. 接下来它要求“NullInjectorError: No provider for Overlay!” 所以我虽然必须从需要添加到提供程序数组中的包中获得此服务。所以我尝试从它自己的包中导入它,并将它添加到 providers 数组中,如下所示:

从'ngx-toastr/overlay/overlay'导入{覆盖};;

这样做会出现以下错误

找不到模块:错误:无法解析“ngx-toastr/overlay/overlay”

  1. 接下来我尝试搜索这个问题并找到了一些建议添加以下行的stackoverflow解决方案:

从'@angular/cdk/overlay'导入{OverlayModule};

我在每个模块的导入数组中添加了这个模块。什么都没有改变。

现在我不知道要导入什么以及从哪里导入。而且我也不确定我是否正确,或者我应该从哪里开始研究它。我也怀疑这个错误是来自那个包还是什么!!原因它应该在不隐式导入这些服务的情况下工作。

我运行以下命令以在生产构建之前获取错误:

ng 服务 --prod --optimization=false

还请提及如何调试以下错误,在生产构建后的某个时候我们会收到这样的错误,这无疑是没有意义的:

错误错误:“StaticInjectorError[t -> t]: StaticInjectorError(Platform: core)[t -> t]: NullInjectorError: No provider for t!”

我希望我的解释对你有意义。感谢您的宝贵时间,并对这个冗长的问题感到抱歉。

最后仅供参考:我已经删除了节点模块并重新安装了它。

4

1 回答 1

2

确保您使用的 ngx-toastr 版本与您的 angular 和 typescript 版本兼容。https://github.com/scttcper/ngx-toastr#dependencies

ngx-toastr v13 需要角度 >= 10

于 2020-08-13T18:17:22.893 回答