繁体   English   中英

类型 Window 和 typeof globalThis 上不存在属性

[英]Property does not exist on type Window & typeof globalThis

在 Electron-React-Typescript 应用程序中,我收到此错误: Property 'api' does not exist on type 'Window & typeof globalThis'. window.api.send('open-type-A-window', ''); Property 'api' does not exist on type 'Window & typeof globalThis'. window.api.send('open-type-A-window', '');

但是在 index.d.ts 文件中,我以这种方式声明了接口 Window:

declare global {
  namespace NodeJS {
    declare interface Window {
      "electron": {
          openNewWindow(): void;
      },
      "api": {
          send: (channel, data) => {
              ipcRenderer.invoke(channel, data).catch(e => console.log(e))
          },
          receive: (channel, func) => {
            console.log("preload-receive called. args: ");
            ipcRenderer.on(channel, (event, ...args) => func(...args));
          },
          electronIpcSendTo: (window_id: string, channel: string, ...arg: any) => {
            ipcRenderer.sendTo(window_id, channel, arg);
          },
          electronIpcSend: (channel: string, ...arg: any) => {
            ipcRenderer.send(channel, arg);
          },
          electronIpcSendSync: (channel: string, ...arg: any) => {
            return ipcRenderer.sendSync(channel, arg);
          },
          electronIpcOn: (channel: string, listener: (event: any, ...arg: any) => void) => {
            ipcRenderer.on(channel, listener);
          },
          electronIpcOnce: (channel: string, listener: (event: any, ...arg: any) => void) =>
 {
            ipcRenderer.once(channel, listener);
          },
          electronIpcRemoveListener:  (channel: string, listener: (event: any, ...arg: any) 
=> void) => {
            ipcRenderer.removeListener(channel, listener);
          },
          electronIpcRemoveAllListeners: (channel: string) => {
            ipcRenderer.removeAllListeners(channel);
          }
      }
    }
  }
}

我读过这个帖子: https://github.com/Microsoft/TypeScript/issues/19816但我没有得到正确的解决方案。

为了避免此错误,我应该添加/修改什么Property 'api' does not exist on type 'Window & typeof globalThis'

  • 节点:v14.5.0
  • electron:v11.2.3
  • typescript:v4.1.3
  • 操作系统:Ubuntu 18.04.4 桌面

我对 React.js 不熟悉,但我在使用 Electron-Angular 应用程序时遇到了同样的问题。 通过将以下声明添加到我的 app.module.ts 文件中,它允许 TypeScript 识别api object 中的 Z054B8C74CBD96FFF2FDE44

您应该能够通过添加到您的 TS 项目中的主模块来做同样的事情。

declare global {
  interface Window {
    api?: any;
  }
}

在您应该能够在项目中的任何位置简单地执行您的代码之后。

if(window.api) {
  window.api.send('ipcChannel', data);
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM