跳到主要内容
版本:v7

ion-menu

shadow

菜单组件是一种从当前视图侧面滑入的导航抽屉。默认情况下,它使用起始侧(对于 LTR 从左滑入,对于 RTL 从右滑入),但该侧边可以被覆盖。菜单会根据模式以不同方式显示,但显示类型可以更改为任何可用的菜单类型。

菜单元素应是根内容元素的同级元素。可以有任意数量的菜单附加到内容上。这些可以通过模板控制,也可以使用 MenuController 以编程方式控制。

基本用法

菜单切换器

菜单切换器 组件可用于创建可以打开或关闭菜单的自定义按钮。

菜单类型

type 属性可用于自定义菜单在应用程序中的显示方式。

菜单侧边

菜单默认在 "start" 侧显示。在使用从左到右方向的应用程序中,这是左侧;在从右到左的应用程序中,这将是右侧。菜单也可以设置为在 "end" 侧显示,这是 "start" 的对侧。

如果应用程序中两侧都需要菜单,则可以通过将 side 值传递给 MenuController 上的 open 方法来打开菜单。如果未提供侧边,则将打开 "start" 侧的菜单。请参阅下面的 多个菜单 部分,了解使用 MenuController 的示例。

多个菜单

当同一侧存在多个菜单时,我们需要通过 ID 而不是侧边来引用它们。否则,可能会激活错误的菜单。

主题定制

CSS 影子部件

接口

虽然不是必需的,但此接口可以替代 CustomEvent 接口,以便对此组件发出的 Ionic 事件进行更严格的类型检查。

interface MenuCustomEvent<T = any> extends CustomEvent {
detail: T;
target: HTMLIonMenuElement;
}

属性

contentId

DescriptionThe id of the main content. When using a router this is typically ion-router-outlet. When not using a router, this is typically your main view's ion-content. This is not the id of the ion-content inside of your ion-menu.
Attributecontent-id
Typestring | undefined
Defaultundefined

disabled

DescriptionIf true, the menu is disabled.
Attributedisabled
Typeboolean
Defaultfalse

maxEdgeStart

DescriptionThe edge threshold for dragging the menu open. If a drag/swipe happens over this value, the menu is not triggered.
Attributemax-edge-start
Typenumber
Default50
DescriptionAn id for the menu.
Attributemenu-id
Typestring | undefined
Defaultundefined

side

DescriptionWhich side of the view the menu should be placed.
Attributeside
Type"end" | "start"
Default'start'

swipeGesture

DescriptionIf true, swiping the menu is enabled.
Attributeswipe-gesture
Typeboolean
Defaulttrue

type

DescriptionThe display type of the menu. Available options: "overlay", "reveal", "push".
Attributetype
Typestring | undefined
Defaultundefined

事件

NameDescriptionBubbles
ionDidCloseEmitted when the menu is closed.true
ionDidOpenEmitted when the menu is open.true
ionWillCloseEmitted when the menu is about to be closed.true
ionWillOpenEmitted when the menu is about to be opened.true

方法

close

DescriptionCloses the menu. If the menu is already closed or it can't be closed, it returns false.
Signatureclose(animated?: boolean) => Promise<boolean>

isActive

DescriptionReturns true is the menu is active.

A menu is active when it can be opened or closed, meaning it's enabled and it's not part of a ion-split-pane.
SignatureisActive() => Promise<boolean>

isOpen

DescriptionReturns true is the menu is open.
SignatureisOpen() => Promise<boolean>

open

DescriptionOpens the menu. If the menu is already open or it can't be opened, it returns false.
Signatureopen(animated?: boolean) => Promise<boolean>

setOpen

DescriptionOpens or closes the button. If the operation can't be completed successfully, it returns false.
SignaturesetOpen(shouldOpen: boolean, animated?: boolean) => Promise<boolean>

toggle

DescriptionToggles the menu. If the menu is already open, it will try to close, otherwise it will try to open it. If the operation can't be completed successfully, it returns false.
Signaturetoggle(animated?: boolean) => Promise<boolean>

CSS 影子部件

NameDescription
backdropThe backdrop that appears over the main content when the menu is open.
containerThe container for the menu content.

CSS 自定义属性

NameDescription
--backgroundBackground of the menu
--heightHeight of the menu
--max-heightMaximum height of the menu
--max-widthMaximum width of the menu
--min-heightMinimum height of the menu
--min-widthMinimum width of the menu
--widthWidth of the menu

插槽

No slots available for this component.