6

我在网页中使用 Monaco Editor v 0.10.1,想知道是否有人知道是否可以添加一组将在命令面板中弹出的片段 -> 插入片段,就像 Visual Code 编辑器一样。

4

3 回答 3

3
monaco.languages.registerCompletionItemProvider('javascript', {
  provideCompletionItems: () => {
    return {
      suggestions: [
        {
          label: 'Async Block',
          kind: monaco.languages.CompletionItemKind.Snippet,
          documentation: 'Add an async block',
          insertText: [
            '(async () => {',
            '\t',
            '})()'].join('\n')
        }
      ]
    };
  }
});

参考:https ://microsoft.github.io/monaco-editor/playground.html#extending-language-services-completion-provider-example

于 2020-04-11T12:14:28.810 回答
2

您可以使用 AddAction 方法来执行此操作...

//Register a custom snippet
monaco.languages.registerCompletionItemProvider('javascript', {
      provideCompletionItems: () => {
        return [
          {
            label: 'for: Array',
            kind: monaco.languages.CompletionItemKind.Snippet,
            documentation: 'Iterate over an Array',
            insertText: [
              'for(let i=0; i < arr.length; i++){',
              '\tlet elem = arr[i];',
              '',
              '}'].join('\n')
          }
        ]
      }
    });

//Add custom action
this.editor = window.monaco.editor.create(this.$el, options);
window.activeEditor = this.editor
this.editor.addAction({
      id: 'insert-text-at-cusor-command',
      label: 'Command Snippet',
      keybindings: [monaco.KeyMod.CtrlCmd | monaco.KeyCode.F10],
      contextMenuGroupId: 'snippets',
      contextMenuOrder: 1.5,
      run: function (ed) {
        activeEditor.focus()
        activeEditor.trigger('keyboard', 'type', {text: "for"});
      }
});
于 2018-03-08T11:31:33.553 回答
0

不,不是在当前版本中 - 希望很快会有更新版本:) 但是您可以在代码中注册自己的代码段,该代码段将在自动完成/CTRL + SPACE 中可用,然后在命令面板中可用。

于 2018-01-11T22:39:23.527 回答