果你也对鸿蒙开发感爱好,参加“Harmony自习室”吧!扫描下面名片,关注公众号。
Menu是菜单接口,一般用于鼠标右键弹窗、点击弹窗等。
1、创建默认样式的菜单
菜单需要调用bindMenu接口来实现。bindMenu响应绑定组件的点击变乱,绑定组件后手势点击对应组件后即可弹出。
- Button('click for Menu') .bindMenu([ { value: 'Menu1', action: () => { console.info('handle Menu1 select') } } ])
复制代码
2、创建自界说样式的菜单
当默认样式不满足开发需求时,可利用@Builder自界说菜单内容。可通过bindMenu接口进行菜单的自界说。
step1: @Builder开发菜单内的内容
- @State select: boolean = trueprivate iconStr: ResourceStr = $r("app.media.view_list_filled")private iconStr2: ResourceStr = $r("app.media.view_list_filled")@BuilderSubMenu() { Menu() { MenuItem({ content: "复制", labelInfo: "Ctrl+C" }) MenuItem({ content: "粘贴", labelInfo: "Ctrl+V" }) }}@BuilderMyMenu(){ Menu() { MenuItem({ startIcon: $r("app.media.icon"), content: "菜单选项" }) MenuItem({ startIcon: $r("app.media.icon"), content: "菜单选项" }).enabled(false) MenuItem({ startIcon: this.iconStr, content: "菜单选项", endIcon: $r("app.media.arrow_right_filled"), // 当builder参数进行配置时,表示与menuItem项绑定了子菜单。鼠标hover在该菜单项时,会显示子菜单。 builder: this.SubMenu, }) MenuItemGroup({ header: '小标题' }) { MenuItem({ content: "菜单选项" }) .selectIcon(true) .selected(this.select) .onChange((selected) => { console.info("menuItem select" + selected); this.iconStr2 = $r("app.media.icon"); }) MenuItem({ startIcon: $r("app.media.view_list_filled"), content: "菜单选项", endIcon: $r("app.media.arrow_right_filled"), builder: this.SubMenu.bind(this) }) } MenuItem({ startIcon: this.iconStr2, content: "菜单选项", endIcon: $r("app.media.arrow_right_filled") }) }}
复制代码 step2:bindMenu属性绑定组件
- Button('click for Menu') .bindMenu(this.MyMenu)
复制代码 菜单案例如下:
3、创建支持右键或长按的菜单
通过bindContextMenu接口进行菜单的自界说及菜单弹出的触发方式:右键或长按。利用bindContextMenu弹出的菜单项是在独立子窗口内的,可显示在应用窗口外部。
确认菜单的弹出方式,利用bindContextMenu属性绑定组件。示例中为右键弹出菜单。
- Button('click for Menu') .bindContextMenu(this.MyMenu, ResponseType.RightClick)
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |