• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# Menu
2
3以垂直列表形式显示的菜单。
4
5> **说明:**
6>
7> - 该组件从API Version 9开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
8>
9> - Menu组件需和[bindMenu](ts-universal-attributes-menu.md#bindmenu)或[bindContextMenu](ts-universal-attributes-menu.md#bindcontextmenu8)方法配合使用,不支持作为普通组件单独使用。
10
11## 子组件
12
13包含[MenuItem](ts-basic-components-menuitem.md)、[MenuItemGroup](ts-basic-components-menuitemgroup.md)子组件。
14
15## 接口
16
17Menu()
18
19作为菜单的固定容器,无参数。
20
21> **说明:**
22> 菜单和菜单项宽度计算规则:
23>
24> 布局过程中,期望每个菜单项的宽度一致。若子组件设置了宽度,则以[尺寸计算规则](ts-universal-attributes-size.md#constraintsize)为准。
25>
26> 不设置宽度的情况:菜单组件会对子组件MenuItem、MenuItemGroup设置默认2栅格的宽度,若菜单项内容区比2栅格宽,则会自适应撑开。
27>
28> 设置宽度的情况:菜单组件会对子组件MenuItem、MenuItemGroup设置减去padding后的固定宽度。
29
30## 属性
31
32除支持[通用属性](ts-universal-attributes-size.md)外,还支持以下属性:
33
34| 名称     | 参数类型                  | 描述                                                             |
35| -------- | ------------------------- | ---------------------------------------------------------------- |
36| fontSize<sup>(deprecated)</sup> | [Length](ts-types.md#length) | 统一设置Menu中所有文本的尺寸,Length为number类型时,使用fp单位。<br/>从API Version 10开始废弃,建议使用font代替。 |
37| font<sup>10+</sup> | [Font](ts-types.md#font) | 统一设置Menu中所有文本的字体样式。 |
38| fontColor<sup>10+</sup> | [ResourceColor](ts-types.md#resourcecolor) | 统一设置Menu中所有文本的颜色。 |
39| radius<sup>10+</sup> | [Dimension](ts-types.md#dimension10) \| [BorderRadiuses](ts-types.md#borderradiuses9) | 设置Menu边框圆角半径。<br/> 默认值跟随主题。数值高于menu宽度的一半时,走默认值。 |
40| width<sup>10+</sup> | [Length](ts-types.md#length) | 设置Menu边框宽度。<br/> 支持设置的最小宽度为64vp。 |
41
42## 示例
43
44```ts
45@Entry
46@Component
47struct Index {
48  @State select: boolean = true
49  private iconStr: ResourceStr = $r("app.media.view_list_filled")
50  private iconStr2: ResourceStr = $r("app.media.view_list_filled")
51
52  @Builder
53  SubMenu() {
54    Menu() {
55      MenuItem({ content: "复制", labelInfo: "Ctrl+C" })
56      MenuItem({ content: "粘贴", labelInfo: "Ctrl+V" })
57    }
58  }
59
60  @Builder
61  MyMenu(){
62    Menu() {
63      MenuItem({ startIcon: $r("app.media.icon"), content: "菜单选项" })
64      MenuItem({ startIcon: $r("app.media.icon"), content: "菜单选项" })
65        .enabled(false)
66      MenuItem({
67        startIcon: this.iconStr,
68        content: "菜单选项",
69        endIcon: $r("app.media.arrow_right_filled"),
70        builder: ():void=>this.SubMenu()
71      })
72      MenuItemGroup({ header: '小标题' }) {
73        MenuItem({ content: "菜单选项" })
74          .selectIcon(true)
75          .selected(this.select)
76          .onChange((selected) => {
77            console.info("menuItem select" + selected);
78            this.iconStr2 = $r("app.media.icon");
79          })
80        MenuItem({
81          startIcon: $r("app.media.view_list_filled"),
82          content: "菜单选项",
83          endIcon: $r("app.media.arrow_right_filled"),
84          builder: ():void=>this.SubMenu()
85        })
86      }
87      MenuItem({
88        startIcon: this.iconStr2,
89        content: "菜单选项",
90        endIcon: $r("app.media.arrow_right_filled")
91      })
92    }
93  }
94
95  build() {
96    Row() {
97      Column() {
98        Text('click to show menu')
99          .fontSize(50)
100          .fontWeight(FontWeight.Bold)
101      }
102      .bindMenu(this.MyMenu)
103      .width('100%')
104    }
105    .height('100%')
106  }
107}
108```
109
110![menu1](figures/menu1.png)
111