在electron.service.ts的文件夹提供程序中,我有代码:
import { Injectable } from '@angular/core';
// If you import a module but never use any of the imported values other than as TypeScript types,
// the resulting javascript file will look as if you never imported the module at all.
import { ipcRenderer, webFrame, remote, BrowserWindow } from 'electron';
import * as childProcess from 'child_process';
import * as fs from 'fs';
@Injectable()
export class ElectronService {
ipcRenderer: typeof ipcRenderer;
webFrame: typeof webFrame;
remote: typeof remote;
childProcess: typeof childProcess;
win: BrowserWindow;
fs: typeof fs;
constructor() {
// Conditional imports
if (this.isElectron()) {
this.ipcRenderer = window.require('electron').ipcRenderer;
this.webFrame = window.require('electron').webFrame;
this.remote = window.require('electron').remote;
this.win = window.require('electron').remote.getCurrentWindow();
this.childProcess = window.require('child_process');
this.fs = window.require('fs');
}
}
isElectron = () => {
return window && window.process && window.process.type;
}
}
在组件中,我有方法:
import { ElectronService } from '../../providers/electron.service';
toggleFullScreen() {
const flag = !this.electron.win.isFullScreen();
this.electron.win.show();
this.electron.win.setFullScreen(flag);
this.storeService.isFullScreen = this.electron.win.isFullScreen();
}
在我写项目时
win: BrowserWindow;
我收到错误找不到名称“ BrowserWindow”。怎么了?我做了 从'electron'导入{ipcRenderer,webFrame,remote,BrowserWindow}; 我不能改写
win: typeof BrowserWindow;
因为在方法toggleFullScreen()中将无法使用方法isFullScreen(),show(),setFullScreen()。 应用程式在开发模式下运作良好,但出现错误,无法建立exe档案。如何解决?
答案 0 :(得分:1)
这是我所熟悉的
const {BrowserWindow} = require('electron')
let win = new BrowserWindow({width: 800, height: 600})
编辑:我在网上看到的类型指定为
win: Electron.BrowserWindow