如何从Visual Studio Code API打开浏览器

问题描述 投票:5回答:3

我正在探索一种方法,以便从用于开发扩展的Visual Studio Code API打开默认浏览器。

以下是我的代码:

var disposable = vscode.commands.registerCommand('extension.browser', () => {
  // The code you place here will be executed every time your command is executed
  vscode.Uri.call("http://facebook.com");
});

如何使用vscode类从API打开浏览器URL。

javascript node.js typescript visual-studio-code vscode-extensions
3个回答
14
投票

不需要节点或外部库。

如果您使用的是VS Code 1.31+,请使用vscode.env.open函数:

import * as vscode from 'vscode';

vscode.env.openExternal(vscode.Uri.parse('https://example.com'));

对于较旧的VS Code版本,请使用vscode.open命令:

vscode.commands.executeCommand('vscode.open', vscode.Uri.parse('https://example.com'))

这两个都将在用户的默认浏览器中打开页面


1
投票

我必须使用npm open url才能在浏览器中打开。

var openurl = require('openurl').open;
    openurl("http://google.com");

0
投票

您不需要安装外部依赖项。只需使用Node.js库和系统命令即可打开URL。对于例如使用child_process.exec打开一个URL。

声明一个这样的函数:

const exec = require('child_process').exec;

function openURL(url) {
  let opener;

  switch (process.platform) {
    case 'darwin':
      opener = 'open';
      break;
    case 'win32':
      opener = 'start';
      break;
    default:
      opener = 'xdg-open';
      break;
  }

  return exec(`${opener} "${url.replace(/"/g, '\\\"')}"`);
}

然后从你的代码中调用它

openURL('http://stackoverflow.com');
© www.soinside.com 2019 - 2024. All rights reserved.