在 Angular 中,cdkMenu 与 ngModel 或表单一起使用时,确实可能会遇到一些问题,其中之一是模板的位置不再与按钮相邻。这是因为 cdkMenu 使用了 Overlay 功能,在 DOM 中创建了一个新的层叠层,导致模板的位置改变。
为了解决这个问题,可以使用 ngModel 或表单控件的事件来手动控制 cdkMenu 的打开和关闭。下面是一个示例:
import { Component, ViewChild } from '@angular/core';
import { NgModel } from '@angular/forms';
import { CdkMenuPanel, CdkMenuTrigger } from '@angular/cdk-experimental/menu';
@Component({
selector: 'app-menu-example',
templateUrl: './menu-example.component.html',
styleUrls: ['./menu-example.component.css']
})
export class MenuExampleComponent {
@ViewChild('menu') menu: CdkMenuPanel;
@ViewChild('trigger') trigger: CdkMenuTrigger;
@ViewChild(NgModel) ngModel: NgModel;
isOpen = false;
toggleMenu() {
this.isOpen = !this.isOpen;
if (this.isOpen) {
// 打开 cdkMenu
this.menu.open();
} else {
// 关闭 cdkMenu
this.menu.close();
}
}
selectItem(item: string) {
// 处理选中的项
console.log(item);
// 关闭 cdkMenu
this.menu.close();
}
}
在上面的代码中,我们使用 ViewChild
从模板中获取了 cdkMenuPanel
和 ngModel
。然后,我们在 toggleMenu
方法中根据 isOpen
的状态来手动打开或关闭 cdkMenu。在 selectItem
方法中,我们处理了选中项的逻辑,并手动关闭了 cdkMenu。
请注意,我们使用了 cdkMenuTriggerFor
属性来将 cdkMenu 绑定到按钮,并使用 ViewChild
获取了 cdkMenuPanel
和 cdkMenuTrigger
的实例。
通过这种方式,你就可以手动控制 cdkMenu 的打开和关闭,并解决模板位置不再与按钮相邻的问题。