浏览器唤起本地桌面应用(基础版)

浏览器唤起本地桌面应用(基础版)

适用场景:在 Web 页面中通过点击按钮,直接打开本地安装的桌面端应用。

技术关键词:Windows 注册表、URL Protocol、自定义协议、前端交互


🧩 背景

有时候我们希望从网页一键跳转到本地桌面端软件,桌面端可能是公司内部开发,也可能是第三方开发,提升用户体验,加强软件联动性。 例如我们打开百度网盘的web端,会关联打开桌面端,极大提升用户体验

本文以vscode为案例,将手把手教你如何通过注册表注册协议,并在网页中通过 JavaScript 唤起本地桌面应用。


🔧 步骤一:创建并导入注册表文件

1. 创建 .reg 文件

新建一个文本文件,粘贴以下内容:

reg 复制代码
Windows Registry Editor Version 5.00

[HKEY_CLASSES_ROOT\vscode]
@="URL:vscode Protocol"
"URL Protocol"=""

[HKEY_CLASSES_ROOT\vscode\DefaultIcon]
@="C:\\Program Files\\Microsoft VS Code\\Code.exe"

⚠️ 注意:请根据你本机 VS Code 的实际安装路径修改 @= 后的路径。

2. 保存为注册表文件

将文件保存为 vscode.reg(确保扩展名是 .reg,不是 .txt)

建议放到桌面方便操作

3. 导入注册表

双击 vscode.reg,系统会弹出确认窗口,点击"是"即可将协议注册到 Windows。

🌐 步骤二:在网页中唤起 VS Code

在 HTML 中添加一个按钮,通过 JavaScript 触发自定义协议:

html 复制代码
<button id="openDesktop">唤起桌面端</button>

<script>
  document.getElementById('openDesktop').addEventListener('click', () => {
    window.location.href = 'vscode://open';
  });
</script>

✅ 点击按钮后,如果注册成功,系统会自动启动 VS Code。

💡 提示:vscode://open/ 是 VS Code 官方支持的基础协议,还可以附加参数,例如:

js 复制代码
vscode://file/C:/my-project/main.js

成果展示

🧹 步骤三:清理(可选)

如果你只是临时测试,建议清理注册表避免残留:

  1. 删除桌面上的 vscode.reg 文件
  2. 按下 Win + R,输入 regedit 打开注册表编辑器
  3. 导航到 HKEY_CLASSES_ROOT\vscode
  4. 右键 → 删除整个 vscode 项

⚠️ 操作注册表前建议备份,误删可能导致系统异常。

✅ 总结

通过注册表注册自定义协议,我们可以实现 Web 与本地应用的深度联动。

虽然本文以 VS Code 为例,但该方法适用于任何支持命令行启动的桌面程序(如 IDEA、Typora、Obsidian 等)。

安全提醒:自定义协议可能被恶意网站滥用,现代浏览器对此有一定限制(如 Chrome 会弹出确认框),生产环境中需谨慎使用。

参考资料:

相关推荐
qq_177767375 分钟前
React Native鸿蒙跨平台数据使用监控应用技术,通过setInterval每5秒更新一次数据使用情况和套餐使用情况,模拟了真实应用中的数据监控场景
开发语言·前端·javascript·react native·react.js·ecmascript·harmonyos
烬头88218 分钟前
React Native鸿蒙跨平台应用实现了onCategoryPress等核心函数,用于处理用户交互和状态更新,通过计算已支出和剩余预算
前端·javascript·react native·react.js·ecmascript·交互·harmonyos
天人合一peng3 小时前
Unity中button 和toggle监听事件函数有无参数
前端·unity·游戏引擎
方也_arkling3 小时前
别名路径联想提示。@/统一文件路径的配置
前端·javascript
毕设源码-朱学姐3 小时前
【开题答辩全过程】以 基于web教师继续教育系统的设计与实现为例,包含答辩的问题和答案
前端
web打印社区4 小时前
web-print-pdf:突破浏览器限制,实现专业级Web静默打印
前端·javascript·vue.js·electron·html
RFCEO4 小时前
前端编程 课程十三、:CSS核心基础1:CSS选择器
前端·css·css基础选择器详细教程·css类选择器使用方法·css类选择器命名规范·css后代选择器·精准选中嵌套元素
Amumu121384 小时前
Vuex介绍
前端·javascript·vue.js
We་ct4 小时前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript
2601_949480065 小时前
【无标题】
开发语言·前端·javascript