Electron开发: Electron 自定义协议
2022-04-18 本文已影响0人
you的日常
1. 协议: 从网页端唤起Electron应用
Elelctron 提供了一个方式来自动唤起 Electron应用,这一次就让我们来学学如何通过连接来唤起Electron 应用,并且我们可以使用这个功能来做点什么。
1.1 协议唤起示例:
image.png1.2 什么是协议
Electron 注册的协议, Electron 会将协议注册到系统的协议列表中,它是系统层级的 API,只能在当前系统下使用, 其他未注册协议的电脑不能识别。
Electron 的 app 模块提供了一些处理协议的方法, 这些方法允许您设置协议和取消协议, 来让你的应用成为默认的应用程序。
1.3 协议的作用
注册一个协议到系统协议中, 当通过其他应用/浏览器网页端打开新协议的链接时,浏览器会检测该协议有没有在系统协议中, 如果该协议注册过,然后唤起协议的默认处理程序(我们的应用)。
1.4 注册协议: app.setAsDefaultProtocolClient
协议需要在ready事件后注册,具体代码如下.
// 注册自定义协议
const { app } = require('electron')
const path = require('path')
// 注册自定义协议
function setDefaultProtocol() {
const agreement = 'electron-playground-code' // 自定义协议名
let isSet = false // 是否注册成功
app.removeAsDefaultProtocolClient(agreement) // 每次运行都删除自定义协议 然后再重新注册
// 开发模式下在window运行需要做兼容
if (process.env.NODE_ENV === 'development' && process.platform === 'win32') {
// 设置electron.exe 和 app的路径
isSet = app.setAsDefaultProtocolClient(agreement, process.execPath, [
path.resolve(process.argv[1]),
])
} else {
isSet = app.setAsDefaultProtocolClient(agreement)
}
console.log('是否注册成功', isSet)
}
setDefaultProtocol()<
1.5 使用协议
使用方式: 在浏览器地址栏输入注册好的协议,即可唤起应用。
协议唤起的链接格式: 自协议名称: //参数
比如上文注册: electron-playground-code
协议,触发时会默认带上 ://
。
在使用的时候, 需要在浏览器地址栏输入:
electron-playground-code://1234
// 1234是参数 可根据业务自行修改