Monaco 使用 RenameProvider

Monaco 重命名是编辑器标配,可以重命名变量名称。重命名包括两部分,首先是列出 Rename 的名称,第二步是重命名后文字和对应位置信息,用于替换。先看一下效果:
在这里插入图片描述

通过 registerRenameProvider 注册 RenameProvider 的处理函数。
在这里插入图片描述
右键变量名称点击重命名,resolveRenameLocation 返回名称,provideRenameEdits 返回最终更新文字和对应的位置信息。
在这里插入图片描述

provideRenameEdits

返回修改文字和对应位置信息 WorkspaceEdit
在这里插入图片描述
IWorkspaceTextEdit 包含以下信息,versionId 直接通过 model.getVersionId 获取当前版本号

在这里插入图片描述
TextEdit 包含文字和位置信息
在这里插入图片描述

resolveRenameLocation

返回 Rename 变量名和显示位置
在这里插入图片描述

代码实现如下


export function renameProvider(
  editor: monacoEditor.editor.IStandaloneCodeEditor,
  monaco: typeof monacoEditor
) {
  return monaco.languages.registerRenameProvider("mySpecialLanguage", {
    provideRenameEdits: function (model, position, newName, token) {

      var word = model.getWordAtPosition(position);
      
      if (!word) {
        return {
          edits: [ ]
        };
      }
      var range = new monaco.Range(position.lineNumber, word.startColumn, position.lineNumber, word.endColumn);
      
      // Example of a basic rename operation
      return {
        edits: [
          {
            resource: model.uri,
            versionId: model.getVersionId(),
            textEdit: {
              range: range,
              text: newName
            }
          }
        ]
      };
    },
    resolveRenameLocation: function(model, position, token) {
      var word = model.getWordAtPosition(position);
      if (!word) {
        return null;
      }
      return {
        range: new monaco.Range(position.lineNumber, word.startColumn, position.lineNumber, word.endColumn),
        text: word.word
      };
    }
  })
}
  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值