AngularOverlayCDK未附加到原点。
创始人
2024-10-28 19:01:53
0

Angular中的Overlay CDK可用于在应用程序中创建弹出框,工具提示和下拉菜单等内容。 在某些情况下,您可能会遇到Overlay CDK未正确附加到原点的问题。 这可能是由于命名冲突或另一个Angular指令正在与Overlay CDK冲突而导致的。

以下是一些可能的

  1. 检查Overlay CDK directive是否已添加到所需的模块中。 如果未添加,可以通过将其添加到 NgModule 的 @NgModule.decorators 中来解决问题:

import { OverlayModule } from '@angular/cdk/overlay';

@NgModule({ imports: [OverlayModule], // ... }) export class AppModule { }

  1. 确保所需的组件中已正确安装了Angular CDK directive。 在下面的示例中,我们要向用户显示一个工具提示:

import { Component, OnInit } from '@angular/core'; import { Overlay } from '@angular/cdk/overlay'; import { ComponentPortal } from '@angular/cdk/portal';

@Component({ selector: 'app-tooltip', template: 'Hover me for tooltip' }) export class TooltipComponent implements OnInit { private tooltipOverlay: any;

constructor(private overlay: Overlay) {}

ngOnInit(): void {}

showTooltip() { const tooltipPortal = new ComponentPortal(TooltipOverlayComponent); this.tooltipOverlay = this.overlay.create({ positionStrategy: this.overlay.position().connectedTo( document.querySelector('.cdk-overlay-origin')!, { originX: 'start', originY: 'bottom' }, { overlayX: 'start', overlayY: 'top' } ), scrollStrategy: this.overlay.scrollStrategies.close(), }); this.tooltipOverlay.attach(tooltipPortal); }

hideTooltip() { if (this.tooltipOverlay) { this.tooltipOverlay.detach(); } } }

在这个例子中,我们使用了this.overlay.create()方法创建了一个overlay。 该overlay使用了connectedTo()方法沿着元素的底部边缘定位了组件。 请注意,我们使用了选择器.cdk-overlay-origin来定位元素。 您可以使用与此类似的方式调整代码来解决您的问题。

  1. 您可以尝试更新Angular包。 有时,升级Angular包可以解决冲突和错误。

通过使用这些解决

相关内容

热门资讯

安装apache-beam==... 出现此错误可能是因为用户的Python版本太低,而apache-beam==2.34.0需要更高的P...
避免在粘贴双引号时向VS 20... 在粘贴双引号时向VS 2022添加反斜杠的问题通常是由于编辑器的自动转义功能引起的。为了避免这个问题...
Android Recycle... 要在Android RecyclerView中实现滑动卡片效果,可以按照以下步骤进行操作:首先,在项...
omi系统和安卓系统哪个好,揭... OMI系统和安卓系统哪个好?这个问题就像是在问“苹果和橘子哪个更甜”,每个人都有自己的答案。今天,我...
原生ios和安卓系统,原生对比... 亲爱的读者们,你是否曾好奇过,为什么你的iPhone和安卓手机在操作体验上有着天壤之别?今天,就让我...
Android - 无法确定任... 这个错误通常发生在Android项目中,表示编译Debug版本的Java代码时出现了依赖关系问题。下...
Android - NDK 预... 在Android NDK的构建过程中,LOCAL_SRC_FILES只能包含一个项目。如果需要在ND...
Akka生成Actor问题 在Akka框架中,可以使用ActorSystem对象生成Actor。但是,当我们在Actor类中尝试...
Agora-RTC-React... 出现这个错误原因是因为在 React 组件中使用,import AgoraRTC from “ago...
Alertmanager在pr... 首先,在Prometheus配置文件中,确保Alertmanager URL已正确配置。例如:ale...