Monaco 使用 DeclarationProvider

Monaco 中使用 DeclarationProvider,Declaration(声明) 是定义,就像方法的定义,Definition(定义) 是实现,例如 function 的实现。

  • 方法声明
int add(int a, int b);
  • 方法定义
function add(a, b) { // This is a function definition
    return a + b;
}

在方法上点击 Definition
在这里插入图片描述

注册 DeclarationProvider 和 注册 DefinitionProvider 接口参数和返回值都是一致的
在这里插入图片描述
返回 Definition
在这里插入图片描述
实现代码, 返回值为

  • uri:文件地址
  • range:跳转位置
export function declarationProvider(editor, monaco){

  return monaco.languages.registerDeclarationProvider('javascript', {
    provideDeclaration: function(model, position) {
      // Find the word at the position
      const word = model.getWordAtPosition(position);
      if (!word) {
          return { declarations: [] };
      }

      const wordRange = new monaco.Range(position.lineNumber, word.startColumn, position.lineNumber, word.endColumn);
      
      // Define the declaration location
      const declarationLocation = {
          uri: model.uri,
          range: new monaco.Range(1, 1, 1, 10) // Dummy range for the example
      };

      const declarationLocation1 = {
        uri: model.uri,
        range: new monaco.Range(4, 1, 4, 10) // Dummy range for the example
    };

      return [declarationLocation, declarationLocation1]
  }
  });
}

最终效果

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值