Angular 7-多个插座:错误:无法激活已经激活的插座

Ant*_*cke 4 children routerlink router-outlet angular7

这是我在Angular 7中遇到的问题:

我有两个出口:主应用程序路由器出口和一个名为“ administration”的辅助出口。

当我想在开始时浏览任何管理链接时,它可以正常工作。但是下一次,当我尝试导航时,角度抛出此错误消息:

错误:无法激活已经激活的插座

那么,有人可以解释我为什么吗?我在论坛上找不到任何解决方案...

这是一个堆栈闪电战:https ://stackblitz.com/edit/angular-osnnd4

谢谢大家:)

小智 20

这可能很愚蠢,但对于任何寻找解决方案的人来说:确保在任何内部或子出口中都没有未定义的变量。

我在我的项目中修复了这个问题,一切都恢复正常。


小智 9

延迟加载子路由时会发生此问题。每次更改路线时,您都必须手动停用出口。

我已将您的AdministrationComponent修改为以下变通办法。在Angular有办法解决问题之前,它应该可以正常工作。

import { Component, OnInit, ViewChild } from '@angular/core';
import { RouterOutlet, Router, ActivationStart } from '@angular/router';

@Component({
  selector: 'app-administration',
  templateUrl: './administration.component.html',
  styleUrls: ['./administration.component.css']
})
export class AdministrationComponent implements OnInit {

  @ViewChild(RouterOutlet) outlet: RouterOutlet;

  constructor(
    private router: Router
  ) { }

  ngOnInit(): void {
    this.router.events.subscribe(e => {
      if (e instanceof ActivationStart && e.snapshot.outlet === "administration")
        this.outlet.deactivate();
    });
  }
}
Run Code Online (Sandbox Code Playgroud)


Mig*_*dez 5

我的问题:基本上我的命名出口没有停用,在我的情况下,我会将它用于一堆不同的模态,虽然手动停用我的模态出口可以工作,但在将不同的路径和相同的组件加载到出口时它不起作用,所以我无法回收我的组件,在我的例子中是模态组件。

正如@Andreas在这里指出的那样(https://github.com/angular/angular/issues/20694#issuecomment-595707956)。我没有为空路径分配任何组件,所以我猜测它无法以某种方式停用插座,所以我只是为路径分配了一个空组件:“”。

第一种方法:为了解决这个问题,我将使用一个空组件来表示“”或非真实路径

app-router-module.ts
...
 {
    outlet: "modal",
    path: "", 
    component: EmptyComponent, 
  },
...
Run Code Online (Sandbox Code Playgroud)

另一种方法:如果您愿意,可以在关闭视图时执行此操作

model.component.ts

this.router.navigate([
  {
    outlets: {
      modal: null,
    },
  },
]);

Run Code Online (Sandbox Code Playgroud)

无论哪种方式,路由器都会停用,但我认为您应该使用第二个示例,因为它会停用并破坏视图。就我而言,我有一个带有非真实路由的 json,所以我只需将它们映射到 null 值。