我正在开发一个 Electron 应用程序,我想在我的 Main 中的匿名函数中使用 async await,如下所示:
I'm working on an Electron application and I want to use async await in an anonymous function in my Main like this:
process.on("uncaughtException", async (error: Error) => {
await this.errorHandler(error);
});
但这会产生 Typescript 错误
But this yields the Typescript error
在返回 void 的函数参数中返回 Promise预计.
Promise returned in function argument where a void return was expected.
我正在使用 Typescript 3.9.7 和 Electron 9.2.0.
I'm using Typescript 3.9.7 and Electron 9.2.0.
为什么它不允许我使用 async/await?
Why doesn't it allow me to use async/await?
您可以使用异步 IIFE 在回调中,像这样:
You can use an asynchronous IIFE inside the callback, like this:
process.on("uncaughtException", (error: Error) => {
(async () => {
await this.errorHandler(error);
// ...
})();
});
这确保回调的隐式返回保持undefined,而不是一个promise.
This ensures that the implicit return of the callback remains undefined, rather than being a promise.
这篇关于在预期返回 void 的函数参数中返回 Promise的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!
在 Electron 渲染器进程中创建子窗口时如何修复How to fix BrowserWindow is not a constructor error when creating child window in Electron renderer process(在 Electron 渲染器进程中创建子窗口
mainWindow.loadURL("https://localhost:3000/") 在 EmainWindow.loadURL(quot;https://localhost:3000/quot;) show white screen on Electron app(mainWindow.loadURL(https://localhost:3000/) 在 Electron 应用程
Electron webContents executeJavaScript:无法在第二个 loaElectron webContents executeJavaScript : Cannot execute script on second on loadURL(Electron webContents executeJavaScript:无法在第二个 loadURL 上
如何在angular-cli的组件内使用电子浏览器窗口?how to use electron browser window inside components in angular-cli?(如何在angular-cli的组件内使用电子浏览器窗口?)
ElectronJS - 在 Windows 之间共享 redux 存储?ElectronJS - sharing redux store between windows?(ElectronJS - 在 Windows 之间共享 redux 存储?)
如何在电子应用程序中访问相机/网络摄像头?How to access camera/webcamera inside electron app?(如何在电子应用程序中访问相机/网络摄像头?)