2022-12-22 06:18:49 +08:00

1.3 KiB
Raw Blame History

title, sidebar_position
title sidebar_position
hotkey - 快捷键 API 5

模块简介

绑定快捷键 API可以自定义项目快捷键使用。

方法签名functions

bind

绑定快捷键

类型定义

function bind(
	combos: string[] | string,
	callback: (e: KeyboardEvent, combo?: string) => any | false,
	action?: string
): () => void;

示例

hotkey.bind('command+s', (e) => {
  e.preventDefault();
  // command+s 快捷键按下时需要执行的逻辑
});

使用示例

基础示例

hotkey.bind('command+s', (e) => {
  e.preventDefault();
  // command+s 快捷键按下时需要执行的逻辑
});

同时绑定多个快捷键

hotkey.bind(['command+s', 'command+c'], (e) => {
  e.preventDefault();
  // command+s 或者 command+c 快捷键按下时需要执行的逻辑
});

保存快捷键配置

import {
  hotkey,
} from '@alilc/lowcode-engine';

function saveSchema(schema) {
  // 保存 schema 相关操作
}

const saveSampleHotKey = (ctx: IPublicModelPluginContext) => {
  return {
    name: 'saveSample',
    async init() {
      hotkey.bind('command+s', (e) => {
        e.preventDefault();
        saveSchema();
      });
    },
  };
}

saveSampleHotKey.pluginName = 'saveSampleHotKey';
plugins.register(saveSampleHotKey);