应在 ready 之前对 open-file
进行监听。如果自己接管文件的打开,应该**event.preventDefault()
**
触发条件:
-
应用已经打开,并且通过扩展名或者 macOS 命令行中的 open 命令打开文件的时候,触发
-
拖放一个文件到 Dock 但应用还没有运行的时候触发
Windows 电脑中,需要通过主进程的 process.argv 进行解析
事件:****open-url
返回:****event
: Event, url
: string
事件open-url
是系统通过 Electron 应用打开 url 时触发,如果想要自己接管打开url,应该调用**event.preventDefault()
**。并且要在 info.plist 中定义 url scheme,如果是 Electron Builder 打包的,可以找到 extendInfo 配置,能省去很多麻烦。
原话是这么说的:Your application’s Info.plist file must define the URL scheme within the CFBundleURLTypes key, and set NSPrincipalClass to AtomApplication.
// main.ts
// for electron-test://abc?query1=value1
app.setAsDefaultProtocolClient(‘electron-test’);
app.on(‘will-finish-launching’, (event: Event) => {
log(==> app-event: will-finish-launching <===
);
app.on(‘open-url’, (event: Event, url: string) => {
log(==> app-event: open-url <===
, url);
});
});
这样在实现后,比如在浏览器中输入electron-test://abc?query1=value1 地址就可以打开 Electron 应用,并且open-url 就可以捕获到这个路径信息。
事件:****activate
[macOS]
返回:****event
: Event, hasVisibleWindows
: boolean
事件activate
只会在【首次启动应用程序】、【在程序已经运行后再次打开程序】或【单击应用程序的坞站或任务栏图标时】重新激活它。如果是使用 Cmd+Tab
切换,是不会激活的,这个时候需要**did-become-active
** 。
这里的再次打开程序是,macOS 默认是让应用单例模式,如果尝试运行另外一个实例,就会 activate 已经运行的实例。
事件:****did-become-active
返回:event: Event
事件**did-become-active
**则会在切换到这个应用的时候触发,比如没有窗口的应用或者程序第一次启动。
事件:****session-created
返回:session
: Session
创建一个 default session,常用于网络请求环境的隔离。
事件:****web-contents-created
返回:****event
Event,window
: BrowserWindow
创建 webContents 的上下文环境就绪。有可能会被初始化多次
事件:****browser-window-created
返回:event: Event, window
: BrowserWi