Menu

优质
小牛编辑
138浏览
2023-12-01

Menu是一个侧滑菜单。

使用方法

Menu必须指定一个参考的content

  1. <ion-menu [content]="mycontent">
  2. <ion-content>
  3. <ion-list>
  4. ...
  5. </ion-list>
  6. </ion-content>
  7. </ion-menu>
  8. <ion-nav #mycontent [root]="rootPage"></ion-nav>

默认情况下菜单在左边滑动,你也可以使用side属性来让它从右边滑出。

  1. <ion-menu side="right" [content]="mycontent">...</ion-menu>

如果你只是想简单的使用menu那么你可以使用menuToggle menuClose来控制menu的滑出和收回。

  1. <button ion-item menuClose="leftMenu" detail-none>
  2. Close Menu
  3. </button>
  4. <button menuToggle>
  5. <ion-icon name='menu'></ion-icon>
  6. </button>

如果你有多个menu从同一边滑出,你可以通过id来控制。

  1. <ion-menu id="authenticated" side="left" [content]="mycontent">...</ion-menu>
  2. <ion-menu id="unauthenticated" side="left" [content]="mycontent">...</ion-menu>
  3. <ion-nav #mycontent [root]="rootPage"></ion-nav>
  1. enableAuthenticatedMenu() {
  2. this.menu.enable(true, 'authenticated');
  3. this.menu.enable(false, 'unauthenticated');
  4. }

注意:如果你只有一个menu那么请不用使用id控制。尽量避免使用id。

Menu Types

menu可以设置显示的类型。

  • overlay是传统的MD设计
  • reveal是传统的ios设计

默认情况下,它们将自动使用当前平台的类型。

注:原文中还提到了一个push,我试过后发现和reveal是一样的,而且文章中也没有对push进行过多的解释。

实例方法

open()

打开菜单。返回一个Promise,当菜单被完全打开时,你可以执行一个事件。

close(menuId)

如果menuId为空,那么将关闭所有打开的菜单,如果menuId被设置,那么将关闭指定的菜单。返回一个Promise

toggle(menuId)

菜单开关。如果菜单当前关闭,那么将打开,如果菜单当前打开,将被关闭。
返回一个Promise

enable(menuId)

当你有多个menu的时候,用于启用或禁用menu。当你启用一个menu那么同方向的其他menu将被禁用。
返回一个menu实例。

swipeEnable(shouldEnable,menuId)

isOpen()

返回一个布尔值来表示menu是否处于打开状态

isEnabled

返回一个布尔值来表示menu是否被启用

get(menuId)

返回一个menu实例,如果menuId的menu没有找到,那么将会返回null

getMenus()

返回menu实例数组