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

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

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


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


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

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

谢谢大家:)

最佳答案

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

我已将您的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();
    });
  }
}

09-25 18:46