- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们有一个遗留应用程序,其中包括 POJavascript、原型(prototype)和 jquery。
我们正在以 Angular 一次一个部分地重写应用程序。目前我们已经用angular4重写了一些部分。我们正在使用 webpack 来捆绑 angular4 应用程序,包括应用程序登陆页面中的 Angular bundle ,效果很好; webpack 开发服务器也运行良好。
现在,我正在尝试升级到 Angular CLI 和 Angular v6.2.1。所以,我用 CLI 创建了一个新项目,然后将我的 angular4 源代码复制到这个新项目中,解决了所有错误。 CLI 正在吐出所有必需的脚本。我将这些脚本包含在我的登陆页面中。
对于产品构建,它不会在控制台中显示任何错误,并且不会加载 Angular 应用程序。我尝试使用 ng serve,在着陆页中包含 https://localhost:4200/xxx
脚本,它在控制台中显示以下错误...
注意:如果直接访问 (https://localhost:4200)
没有任何错误,angular App 可以正常工作;但我需要通过我的遗留应用程序的登录页面访问它,因为很多其他的东西都被初始化了,我们需要一部分一部分地发布。我认为这与区域有关,但无法找出确切的问题。
Error: No ErrorHandler. Is platform module (BrowserModule) included?
Stack trace:
["./node_modules/@angular/core/fesm5/core.js"]/PlatformRef.prototype.bootstrapModuleFactory/<@https://localhost:4200/vendor.js:43138:23 [angular]
forkInnerZoneWithAngularBehavior/zone._inner<.onInvoke@https://localhost:4200/vendor.js:42646:24 [angular]
["./node_modules/@angular/core/fesm5/core.js"]/NgZone.prototype.run@https://localhost:4200/vendor.js:42560:16 [<root>]
["./node_modules/@angular/core/fesm5/core.js"]/PlatformRef.prototype.bootstrapModuleFactory@https://localhost:4200/vendor.js:43133:16 [<root>]
["./node_modules/@angular/core/fesm5/core.js"]/PlatformRef.prototype.bootstrapModule/<@https://localhost:4200/vendor.js:43175:53 [<root>]
scheduleResolveOrReject/<@https://localhost:4200/polyfills.js:3194:29 [<root>]
drainMicroTaskQueue@https://localhost:4200/polyfills.js:2917:25 [<root>]
["./node_modules/zone.js/dist/zone.js"]/</ZoneTask.invokeTask@https://localhost:4200/polyfills.js:2822:21 [<root>]
patchEventTarget/invokeTask@https://localhost:4200/polyfills.js:3862:9 [<root>]
patchEventTarget/globalZoneAwareCallback@https://localhost:4200/polyfills.js:3888:17 [<root>]
最佳答案
最后,我找到了这个问题的根本原因——PrototypeJS 的 Array.from 与 angular 冲突。
来自 Angular 的 compiler.js 的以下代码引用了从 prototypeJS 初始化的 Array.from(我的遗留应用程序使用它)
function dedupeArray(array) {
if (array) {
return Array.from(new Set(array));
}
return [];
}
要解决此问题,请保存 Array.from 的 Angular 版本并在原型(prototype)脚本加载后重新分配...
<!-- 1. include Angular lib scripts -->
<script type="text/javascript" src="https://localhost:4200/runtime.js"></script>
<script type="text/javascript" src="https://localhost:4200/polyfills.js"></script>
<script type="text/javascript" src="https://localhost:4200/styles.js"></script>
<script type="text/javascript" src="https://localhost:4200/vendor.js"></script>
<!-- 2. save angular version of Array.from -->
<script> var ngArrayFrom = Array.from; </script>
<!-- 3. include Prototype script -->
<script type="text/javascript" src="/prototype.js"></script>
<!-- 4. re-assign Array.from -->
<script> Array.from = ngArrayFrom; </script>
<!-- 5. include angular app script -->
<script type="text/javascript" src="https://localhost:4200/main.js"></script>
它运行良好;但我不知道这是不是最好的方式,是否还有其他冲突的脚本。
关于javascript - 错误: No ErrorHandler. 是否包含平台模块(BrowserModule)?尝试从 jsf 页面加载 Angular 应用程序时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52373971/
我有一个 ServiceExecutor 并运行一个很长的例程(网络服务调用、数据库更新、用户更新等)。由于这些例程可能会导致多个错误,因此我希望在一个位置捕获大量错误。因此我用trycatch包裹它
import { Injectable, ErrorHandler, Inject, Injector } from '@angular/core'; import { MessengerServic
我想创建一个自定义弹出窗口,随时通知用户http error来并显示自定义消息。为此,我创建了一个自定义 event handler看起来像: @Injectable() export class C
我有一个要在多台本地计算机上运行的脚本,但是我没有在其中进行任何错误处理。我根本没有在powershell中进行任何错误处理,因此我在这里完全是菜鸟。我读了一些有关它的内容,但老实说,我只是在寻找一个
我正在研究架构验证。目标是获取 XSD 文件并根据它验证传入文档。如果有错误,我想捕获所有错误。 我只在 ErrorHandler 中收到第一个错误,然后处理结束。互联网上有很多人们问同样问题的例子,
我们正在开发一个 Android 应用程序,我们希望使用 crest 库。我们使用的 Web 服务在某些情况下会因错误请求而返回 400,并带有 json 格式的附加响应数据。我们有一个成功的响应处理
我想编写我的第一个 Alexa Skill,但我的第一个 intent 无法正常工作。错误处理程序出现并响应:“抱歉,...” 我想制作一个飞镖计算器,第一个 intent 应该返回: "Ok ${s
有一个简单的应用程序 var express = require('express'); var http = require('http'); var path=require('path'); v
我有一个这样定义的全局错误处理程序(已删除简化/专有信息): export class ErrorsHandler extends CommonBase implements ErrorHandler
我创建了一个带有几个 activeX 元素的 excelfile。到目前为止,该文件正在按预期工作,现在我正在解决日常业务中可能发生的“用户错误”。 以后使用 activeX 元素(Toggle-、C
我正在尝试遵循 this link 中的示例和 this one但我没有显示错误页面,而是收到了 HTTP 500 内部服务器错误。 我有 在 webconfig 中设置。我什至尝试应用 [Handl
在 Debug模式下,@app.errorhandler 工作,但在生产中,我必须设置 PROPOGATE_EXCEPTIONS=1 才能获得行为。我想知道为什么(安全原因?)。其次,设置了 PROP
我在尝试使用特定场景中的 HttpErrorHandler 机制处理异常时遇到了 Play framework (2.6) 中的问题。 我在根包中有一个简单的ErrorHandler: import
当 errorcontroller 插件捕获错误时,它似乎会召回我的其他注册插件(在它们已经被调用之后)。例如,我有一个 viewsetup 插件,它位于 preDispatch ,设置我的应用程序
我已经使用Camel(当前的版本2.12.2)已有一年多了,而我的一个Web应用程序(数百条路由)遇到了一种有趣的情况。为了克服此问题,我想使用特殊的ErrorHandler,如果在特定的扩展路由中抛
我正在尝试在 dropwizard 1.0.2 中设置自定义 ErrorHandler 在我的运行方法的应用程序类中,我有以下几行: environment.getApplicationConte
我正在尝试按照the documentation在Play Framework(2.6)中加载自定义错误处理程序,但收到以下错误消息- Cannot load play.http.errorHandl
我们目前的情况如前所述,我们有一个巨大的 Angular 应用程序,其中在带有错误处理的各种组件中触发了许多 API 调用,因此错误将通过 toast 消息显示给用户。 在我们的 HttpServic
假设我向服务器发送了post请求以创建用户。如果服务器响应错误,我想从ErrorHandler获取我提交(附加到该请求)的正文(窗体)。这样做的原因是,例如,当“创建用户”失败时,我想显示一个通知,其
我正在尝试首次设置错误处理。 它确实可以工作并报告错误(如果有的话),但是由于某种原因,它始终会为错误处理函数本身显示“缺少参数”的错误。请注意,我的错误处理功能在单独的文件中,并且包含在索引页中,我
我是一名优秀的程序员,十分优秀!