小编Ant*_* S.的帖子

vscode扩展,设置window.activeTextEditor

如何使用 vscode 扩展 api 来设置activeTextEditor

我需要这个的原因是因为我的扩展依赖于对扩展 B 的外部调用,而扩展 B 不接受编辑器的参数。它只是看着vscode.window.activeTextEditor

我的扩展是一个 Web 视图,当在 Web 视图上单击某些内容时,它会调用扩展 B。在那一刻,“活动选项卡”是网络视图,这不是activeTextEditor我想要的。

我想做类似的事情

vscode.window.activeTextEditor = editor
Run Code Online (Sandbox Code Playgroud)

在我的点击处理程序开始时,但这不起作用,因为activeTextEditor不是设置器。

我尝试对相关编辑器进行虚假编辑:

function changeFocus(editor: vscode.TextEditor) {
  return editor.edit((editBuilder) => {
    const pos = new vscode.Position(0, 0);
    const nxt = new vscode.Position(0, 1);
    editBuilder.insert(pos, "\\");
    editBuilder.delete(new vscode.Range(pos, nxt));
  });
}
Run Code Online (Sandbox Code Playgroud)

但这不会改变vscode.window.activeTextEditor变量(它仍然是undefined)。

visual-studio-code vscode-extensions

2
推荐指数
1
解决办法
3518
查看次数