当前位置: 首页 > 知识库问答 >
问题:

Angular 6神秘堆栈跟踪:globalZoneAware回调

江佐
2023-03-14

最近,使用Angular6,我开始在浏览器控制台中观察到异常糟糕的stacktrace描述:

错误错误:"[Object Object]" < br > resolve promise < br > http://localhost:8080/poly fills . js:3136:31 resolve promise < br > http://localhost:8080/poly fills . js:3093:17 scheduleresolverorreject < br > http://localhost:8080/poly fills . js:3195:17 invoke task < br > http://localhost:8080/8080/node _ modules/@ angular/core/Fe sm5/core . js < br >/error handler . prototype . handler error < br > core . js:1719 < br > next < br > core . js:4319:109 < br >。/node _ modules/@ angular/core/Fe sm5/core . js < br >/event emitter . prototype . subscribe/scheduler fn

我怀疑是路由模块中的一些错误,所以我粘贴了我的配置:

const routes = [
  {
    path: 'wordspreview/:id',
    component: WordsPreviewComponent
  },
  {
    path: 'wordspreview',
    component: WordsPreviewComponent
  },
  {
    path: 'search/:query',
    component: SearchResultsComponent
  },
  {
    path: '',
    redirectTo: '/wordspreview',
    pathMatch: 'full'
  }
};

希望有人能帮忙。

共有1个答案

阎承嗣
2023-03-14

我只是为自己找到了错误。

无法在其他任何地方用谷歌搜索它,我将在这里留下解决方案以帮助下一个潜在的受害者:

constructor(private router : Router,
[...]
this.router.navigate([site, id]);

我做错的是导航到错误的< code >站点。这很难调试,因为它只出现在一些罕见的错误< code>site值上。

 类似资料:
  • 当Xdebug被激活时,只要PHP决定显示通知,警告,错误等,就会显示堆栈跟踪。堆栈跟踪显示的信息以及显示方式可以根据您的需要进行配置。 Xdebug在错误情况下显示的堆栈跟踪信息量相当保守(如果display.errors 在php.ini中设置为On)。这是因为大量的信息会减慢脚本的执行速度和浏览器中堆栈跟踪本身的渲染速度。但是,可以使堆栈轨迹以不同的设置显示更详细的信息。 堆栈跟踪中的变量

  • 我使用以下代码打印try-catch块中发生的任何异常,但是当异常发生时,logback不会打印完整的堆栈跟踪,而是写入一行错误(它没有明确说明是什么导致了它。我如何在logback输出中打印完整的堆栈跟踪? 尝试捕获异常的catch块 日志返回错误输出:

  • 问题内容: 程序中没有单个方法“知道”它在堆栈中的位置。它所知道的只是它自己的小工作,它完成了并返回了。因此,当引发异常并打印堆栈跟踪时,它是从哪里来的? 在JVM中监视程序状态的每个应用程序旁边隐式地运行着一个单独的线程吗?还是JVM本身保存此信息,并且在抛出异常时以某种方式从异常中提取数据? 如果是上述两种情况之一,是否可以使用某些调用来检索堆栈跟踪(从监视器线程或JVM) 而不会 引发异常?

  • 问题内容: 当您在Java中使用RMI时,收到异常时将在其前面添加远程堆栈跟踪,如下所示: 那种堆栈跟踪“伪造”如何完成? 我想要什么(除了被迭代)?好吧,如果我能这样做的话,它将对我有帮助: 并使其成为引发日志记录的目的,在堆栈跟踪中也将引发异常(并且方法在链的下游)。 问题答案: 这很容易: Throwable有方法和。 从我的一个项目(非开源,但也许有一天我将打开远程调用引擎): 为了您的方

  • 问题内容: 如何将异常的堆栈跟踪信息打印到stderr以外的流上?我发现的一种方法是使用getStackTrace()并将整个列表打印到流中。 问题答案: 可以接受or或参数: 也就是说,请考虑将SLF4J之类的记录器接口与LOGBack或log4j之类的记录实现一起使用。

  • 问题内容: 有什么方法可以将堆栈跟踪作为字符串获取? 查看调试包(https://golang.org/pkg/runtime/debug/),它只能打印到标准输出。 问题答案: 将格式化的堆栈跟踪放到提供的中。然后,您可以将其转换为字符串。 您还可以使用,分配足够大的缓冲区来容纳整个堆栈跟踪,并使用将该跟踪放入其中,并返回缓冲区()。