harmony 鸿蒙组件快捷键事件

  • 2023-06-24
  • 浏览 (1016)

组件快捷键事件

开发者可以设置组件的自定义组合键,组合键的行为与click行为一致,组件在未获得焦点状态下也可以响应自定义组合键,每个组件可以设置多个组合键。

说明:

从API Version 10开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。

接口

keyboardShortcut(value: string|[FunctionKey], keys: Array<[ModifierKey]>)

参数:

参数名 参数类型 必填 参数描述
value string |FunctionKey 热键的单个字符(可以通过键盘输入的字符)或FunctionKey
keys Array<ModifierKey> 热键组合。

ModifierKey

名称 描述
CTRL 表示键盘上Ctrl键。
SHIFT 表示键盘上Shift键。
ALT 表示键盘上Alt键。

FunctionKey

名称 描述
ESC 表示键盘上ESC功能键。
F1 表示键盘上F1功能键。
F2 表示键盘上F2功能键。
F3 表示键盘上F3功能键。
F4 表示键盘上F4功能键。
F5 表示键盘上F5功能键。
F6 表示键盘上F6功能键。
F7 表示键盘上F7功能键。
F8 表示键盘上F8功能键。
F9 表示键盘上F9功能键。
F10 表示键盘上F10功能键。
F11 表示键盘上F11功能键。
F12 表示键盘上F12功能键。

快捷键使用注意事项

场景 快捷键处理逻辑 例子
所有支持onClick事件的组件 支持自定义组合键
自定义组合键要求 控制键Ctrl,Shift,Alt及它们的组合加上其它可输入字符按键 Button(‘button1’).keyboardShortcut(‘a’,[ModifierKey.CTRL])
多个不同组件设置相同组合键 只响应结点树上的第一个组件、其它组件不响应快捷键。 Button(‘button1’).keyboardShortcut(‘a’,[ModifierKey.CTRL])
Button(‘button2’).keyboardShortcut(‘a’,[ModifierKey.CTRL])
无论组件是否获得焦点 只要窗口获焦快捷键就会响应
绑定单个快捷键时候,通过keyboardShortcut接口value值或者是keys值或两者都是空的情况下。
绑定多个快捷键的时候无法取消快捷键。
取消快捷键的设置 Button(‘button1’).keyboardShortcut(“,[ModifierKey.CTRL])
Button(‘button2’).keyboardShortcut(‘a’,[l])
Button(‘button3’).keyboardShortcut(”,[])
独立pipeline子窗口、主窗口共存的情况下 获焦的窗口响应快捷键
keyboardShortcut接口中的keys命令中ctrl、shift、alt 不区分左右键都响应 Button(‘button1’).keyboardShortcut(‘a’,[ModifierKey.CTRL, ModifierKey.ALT])
keyboardShortcut接口中的value单个字符 不区分大小写都响应 Button(‘button1’).keyboardShortcut(‘a’,[ModifierKey.CTRL])
Button(‘button2’).keyboardShortcut(‘A’,[ModifierKey.CTRL])
快捷键的响应 所有快捷键down的状态下响应、且连续响应
隐藏组件
响应快捷键
disable状态组件 不响应快捷键
1. 组件的组合键(包括系统预定义快捷键)相同时。
2. 接口参数value有多个字符时。
3. 接口参数keys有重复的控制键时。
这几种情况不绑定组合键, 先前绑定的组合键仍然有效 Button(‘button1’).keyboardShortcut(‘c’,[ModifierKey.CTRL])
Button(‘button2’).keyboardShortcut(‘ab’,[ModifierKey.CTRL])
Button(‘button3’).keyboardShortcut(‘ab’,[ModifierKey.CTRL,ModifierKey.CTRL])

系统已有组合键

快捷键 组件
Ctrl + C ImageTextInputTextArea
Ctrl+ A TextInputTextArea
Ctrl+ V TextInputTextArea
Ctrl+ X TextInputTextArea
Shift + 方向键 TextInputTextArea
Ctrl+ Shift+ Z TextInputTextArea
Ctrl+ Z TextInputTextArea
Ctrl+ Y TextInputTextArea
方向键、回车键 TextInputTextArea
TAB键 TextInputTextArea

示例

设置组件的快捷键,同时按控制键+对应的字符可以触发组件响应快捷键,并触发onClick事件或自定义事件。

// xxx.ets
@Entry
@Component
struct Index {
  @State message: string = 'Hello World'

  build() {
    Row() {
      Column() {
        Text(this.message)
        Button("Test short cut 1").onClick((event) => {
          this.message = "I clicked Button 1";
          console.log("I clicked 1");
        }).keyboardShortcut('.', [ModifierKey.SHIFT, ModifierKey.CTRL, ModifierKey.ALT])
          .onKeyEvent((event)=>{
            console.log("event.keyCode: " + JSON.stringify(event));
          })
        Button("Test short cut 2").onClick((event) => {
          this.message = "I clicked Button 2";
          console.log("I clicked 2");
        }).keyboardShortcut('1', [ModifierKey.CTRL])
        Button("Test short cut 3").onClick((event) => {
          this.message = "I clicked Button 3";
          console.log("I clicked 3");
        }).keyboardShortcut('A', [ModifierKey.SHIFT])
        Button("Test short cut 4").onClick((event) => {
          this.message = "I clicked Button 4";
          console.log("I clicked 4");
        }).keyboardShortcut(FunctionKey.F5, [], () => {
          this.message = "I clicked Button 4";
          console.log("I clicked user callback.");
        }).keyboardShortcut(FunctionKey.F3, [])
      }
      .width('100%')
    }
    .height('100%')
  }
}

你可能感兴趣的鸿蒙文章

harmony 鸿蒙基于ArkTS的声明式开发范式

harmony 鸿蒙@ohos.arkui.advanced.Counter(计数器组件)

harmony 鸿蒙@ohos.arkui.advanced.SegmentButton(分段按钮)

harmony 鸿蒙@ohos.multimedia.avCastPicker (投播组件)

harmony 鸿蒙属性动画

harmony 鸿蒙枚举说明

harmony 鸿蒙Blank

harmony 鸿蒙Button

harmony 鸿蒙CalendarPicker

harmony 鸿蒙Checkbox

0  赞