久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

如何從電子的主進程訪問 BrowserWindow Javascript 全局

How to access BrowserWindow Javascript global from main process in electron?(如何從電子的主進程訪問 BrowserWindow Javascript 全局?)
本文介紹了如何從電子的主進程訪問 BrowserWindow Javascript 全局?的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

我想要一個在主進程中定義的菜單,用于在原子/電子應用程序的當前瀏覽器窗口中調用 JS 代碼.

I want a menu, defined in the main process to call JS code inside the current browser window in an atom/electron application.

從瀏覽器窗口獲取主進程全局變量

Getting main process globals form the browser window is

const remote = require('remote')
const foo    = remote.getGlobal('foo')

主進程的等價物是什么(又名獲取當前窗口全局變量).這就是我想用偽代碼做的事情

What is the equivalent for the main process (aka get current window globals). This is what I want to do in pseudo-code

// JS inside main process
const BrowserWindow = require('browser-window')
//...
// Inside the menu callback
let window    = BrowserWindow.getFocusedWindow()
let commander = window.global('commander') /// <---- PSEUDO-CODE !!!
commander.handleCommand('File.Save')

推薦答案

這里 是對您對 api 中 webContents 進程的評論的引用,位于遙控器下的注意:"中.

Here is a reference to your comment about the webContents process in the api, in the "Note:" under remotes.

但是,如果你只是想觸發一個函數,你也可以使用 webContents.send() 和 ipc(main process) 進程觸發相應的代碼運行.像這樣的...

However, if you just want to trigger a function, you could also use the webContents.send() and ipc(main process) processes to trigger the appropriate code to run. Something like this...

// JS inside main process
const window = require('electron').BrowserWindow;

ipc.on('menuItem-selected', function(){
    let focusedWindow    = window.getFocusedWindow();
    focusedWindow.webContents.send('file-save');
});

// Inside the menu callback
require('ipc').on('file-save', function() {
  // File save function call here
});

更新:

對于 Electron 0.35.0 及以上版本,ipc api 更改為:

Update:

For Electron version 0.35.0 and above, the ipc api changed to the following:

// In main process.
const ipcMain = require('electron').ipcMain;

// In renderer process (web page).
const ipcRenderer = require('electron').ipcRenderer;

這篇關于如何從電子的主進程訪問 BrowserWindow Javascript 全局?的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

相關文檔推薦

How to fix BrowserWindow is not a constructor error when creating child window in Electron renderer process(在 Electron 渲染器進程中創建子窗口時如何修復 BrowserWindow 不是構造函數錯誤) - IT屋-程序員軟件開發技術
mainWindow.loadURL(quot;https://localhost:3000/quot;) show white screen on Electron app(mainWindow.loadURL(https://localhost:3000/) 在 Electron 應用程序上顯示白屏)
Electron webContents executeJavaScript : Cannot execute script on second on loadURL(Electron webContents executeJavaScript:無法在第二個 loadURL 上執行腳本)
how to use electron browser window inside components in angular-cli?(如何在angular-cli的組件內使用電子瀏覽器窗口?)
ElectronJS - sharing redux store between windows?(ElectronJS - 在 Windows 之間共享 redux 存儲?)
How to access camera/webcamera inside electron app?(如何在電子應用程序中訪問相機/網絡攝像頭?)
主站蜘蛛池模板: 伊人春色成人网 | 69性欧美高清影院 | 亚洲欧美一区二区三区视频 | 国产区在线观看 | 精品欧美一区二区在线观看视频 | 日韩精品一区二区三区免费视频 | 精品成人佐山爱一区二区 | 久草欧美视频 | 亚洲精品在线免费观看视频 | 精品亚洲永久免费精品 | 中文字幕亚洲精品 | 草草精品 | 久久午夜视频 | 久久久夜色精品亚洲 | 成人在线中文字幕 | 日韩资源| 国产精品久久久久久久久污网站 | 风间由美一区二区三区在线观看 | 草樱av| 欧美亚洲在线视频 | 中文字幕色站 | 国产真实精品久久二三区 | 久久久久国产 | xxx国产精品视频 | 欧美性一级 | 亚洲精选一区二区 | 99精品久久久久久久 | 国产精品久久精品 | 久久免费精品视频 | 色婷婷精品国产一区二区三区 | 久久亚洲一区二区三区四区 | 中文字幕第三页 | 亚洲网站免费看 | 中文字幕在线一区二区三区 | 国产精品视频区 | 欧美日韩高清在线一区 | 巨大荫蒂视频欧美另类大 | 黄色大片免费播放 | 亚洲精品在线91 | 亚洲精品久久久一区二区三区 | 夜夜撸av |