Menu 导航菜单

为页面和功能提供导航的菜单列表。

何时使用

导航菜单是一个网站的灵魂,用户依赖导航在各个页面中进行跳转。一般分为顶部导航和侧边导航,顶部导航提供全局性的类目和功能,侧边导航提供多级结构来收纳和排列网站架构。

代码演示

顶部导航

水平的顶部导航菜单。

expand code expand code

内嵌菜单

垂直菜单,子菜单内嵌在菜单区域。

expand code expand code

缩起内嵌菜单

内嵌菜单可以被缩起/展开。

expand code expand code

只展开当前父级菜单

点击菜单,收起其他展开的所有菜单,保持菜单聚焦简洁。

expand code expand code

垂直菜单

子菜单是弹出的形式。

expand code expand code


主题

内建了两套主题 light|dark,默认 light

expand code expand code
Change Mode Change Theme

切换菜单类型

展示动态切换模式。

expand code expand code

单文件递归菜单

使用单文件方式递归生成菜单。
因组件内部会动态更改a-sub-menu的属性,如果拆分成单文件,无法将属性挂载到a-sub-menu上,你需要自行声明属性并挂载。为了方便,避免属性的声明,我们推荐使用函数式组件。

expand code expand code

API

<template>
  <a-menu>
    <a-menu-item>菜单项</a-menu-item>
    <a-sub-menu title="子菜单">
      <a-menu-item>子菜单项</a-menu-item>
    </a-sub-menu>
  </a-menu>
</template>
参数 说明 类型 默认值
defaultOpenKeys 初始展开的 SubMenu 菜单项 key 数组
defaultSelectedKeys 初始选中的菜单项 key 数组 string[]
forceSubMenuRender 在子菜单展示之前就渲染进 DOM boolean false
inlineCollapsed inline 时菜单是否收起状态 boolean -
inlineIndent inline 模式的菜单缩进宽度 number 24
mode 菜单类型,现在支持垂直、水平、和内嵌模式三种 string: vertical vertical-right horizontal inline vertical
multiple 是否允许多选 boolean false
openKeys(.sync) 当前展开的 SubMenu 菜单项 key 数组 string[]
selectable 是否允许选中 boolean true
selectedKeys(v-model) 当前选中的菜单项 key 数组 string[]
subMenuCloseDelay 用户鼠标离开子菜单后关闭延时,单位:秒 number 0.1
subMenuOpenDelay 用户鼠标进入子菜单后开启延时,单位:秒 number 0
theme 主题颜色 string: light dark light
事件名称 说明 回调参数
click 点击 MenuItem 调用此函数 function({ item, key, keyPath })
deselect 取消选中时调用,仅在 multiple 生效 function({ item, key, selectedKeys })
openChange SubMenu 展开/关闭的回调 function(openKeys: string[])
select 被选中时调用 function({ item, key, selectedKeys })
参数 说明 类型 默认值
disabled 是否禁用 boolean false
key item 的唯一标志 string
title 设置收缩时展示的悬浮标题 string
参数 说明 类型 默认值
disabled 是否禁用 boolean false
key 唯一标志 string
title 子菜单项值 string|slot

Menu.SubMenu 的子元素必须是 MenuItem 或者 SubMenu.

事件名称 说明 回调参数
titleClick 点击子菜单标题 ({ key, domEvent })
参数 说明 类型 默认值
title 分组标题 string||function|slot

Menu.ItemGroup 的子元素必须是 MenuItem.

菜单项分割线,只用在弹出菜单内。

  Dropdown 下拉菜单Pagination 分页