欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Electron主進(jìn)程(Main?Process)與渲染進(jìn)程(Renderer?Process)通信詳解

 更新時(shí)間:2024年03月11日 14:22:50   作者:明天也要努力  
這篇文章主要介紹了Electron主進(jìn)程(Main?Process)與渲染進(jìn)程(Renderer?Process)通信,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

渲染進(jìn)程向主進(jìn)程通信

修改 html 文件內(nèi)容

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <!-- 解決控制臺(tái)警告問題 -->
  <meta http-equiv="Content-Security-Policy" content="default-src 'self' 'unsafe-inline';">
  <title>electron</title>
</head>
<body>
  <input type="text" id="name">
  <button id="btn">send</button>
  <script src="./renderer/app.js"></script>
</body>
</html>

根目錄下新增 renderer 文件夾

在 renderer 文件夾下新増 app.js 文件,此處的文件表示渲染進(jìn)程的 js 文件,可以操作渲染進(jìn)程(瀏覽器)中的dom。

const button = document.getElementById('btn');

button.addEventListener('click',() => {
  // 此處的electronAPI即為預(yù)加載中傳遞的命名空間,sendMainInfo為傳遞過來的回調(diào)函數(shù)
  const name = document.getElementById('name').value;
  electronAPI.sendMainInfo(name);
})

在根目錄下新増 preload.js 文件

// 此文件為預(yù)加載文件,需在 main.js 文件中配置
const { ipcRenderer,contextBridge } = require('electron');

/*
* 搭建主進(jìn)程和渲染進(jìn)程的橋梁
*/ 
// render-info代表主進(jìn)程可以監(jiān)聽的回調(diào)函數(shù)
const sendMainInfo = async (val) => {
  ipcRenderer.invoke('render-info',val);
}
// electronAPI 代表向渲染進(jìn)程傳遞的對(duì)象命名,sendMainInfo表示向渲染進(jìn)程傳遞一個(gè)回調(diào)函數(shù)
contextBridge.exposeInMainWorld('electronAPI',{
  platform: process.platform,
  sendMainInfo,
});

修改主進(jìn)程(main.js)文件

const { app, BrowserWindow, ipcMain} = require('electron');
const path = require('path');

const createWindow = () => {
  const win = new BrowserWindow({
    width: 1200,
    height: 1000,
    webPreferences:{
      preload: path.resolve(__dirname,'./preload.js') // 渲染進(jìn)程預(yù)加載
    }
  });
  // 加載靜態(tài)資源
  win.loadFile('index.html');
  // 打開開發(fā)者工具
  win.webContents.openDevTools();
};

// 主進(jìn)程監(jiān)聽渲染進(jìn)程傳遞過來的回調(diào)函數(shù)
ipcMain.handle('render-info',(event,args) => {
  console.log(args)
})


// app.whenReady 表示主進(jìn)程加載完成,返回 promise 
app.whenReady().then(() => {
  createWindow();
  app.on('activate', () => {
    // 此處解決mac系統(tǒng)關(guān)閉app后,但程序塢中還存在圖標(biāo),再次點(diǎn)擊可以重新創(chuàng)建進(jìn)程
    if(BrowserWindow.getAllWindows.length === 0){
      createWindow();
    } 
  })
});


// 關(guān)閉所有窗口
app.on('window-all-closed', () => {
  // electron 運(yùn)行在三個(gè)環(huán)境(win32 Windows系統(tǒng)、linux Linux系統(tǒng)、 darwin Mac系統(tǒng))
  // 此處解決的是非mac系統(tǒng),程序退出進(jìn)程 (Mac系統(tǒng)關(guān)閉app會(huì)保留在程序塢中)
  if(process.platform !== 'darwin'){
    app.quit();
  } 
})
  • 效果

主進(jìn)程向渲染進(jìn)程通信

修改主進(jìn)程(main.js)文件

const { app, BrowserWindow, ipcMain} = require('electron');
const path = require('path');

const createWindow = () => {
  const win = new BrowserWindow({
    width: 1200,
    height: 1000,
    webPreferences:{
      preload: path.resolve(__dirname,'./preload.js') // 渲染進(jìn)程預(yù)加載
    }
  });
  // 加載靜態(tài)資源
  win.loadFile('index.html');
  // 打開開發(fā)者工具
  win.webContents.openDevTools();
};


// 主進(jìn)程監(jiān)聽渲染進(jìn)程傳遞過來的回調(diào)函數(shù)
ipcMain.handle('main-info',async (event,args) => {
  return await getInfo();
})

// mock 一個(gè)接口
function getInfo() {
  return new Promise(resolve => {
    setTimeout(() => {
      resolve('來自主進(jìn)程的數(shù)據(jù)');
    }, 500)
  })
}

// app.whenReady 表示主進(jìn)程加載完成,返回 promise 
app.whenReady().then(() => {
  createWindow();
  app.on('activate', () => {
    // 此處解決mac系統(tǒng)關(guān)閉app后,但程序塢中還存在圖標(biāo),再次點(diǎn)擊可以重新創(chuàng)建進(jìn)程
    if(BrowserWindow.getAllWindows.length === 0){
      createWindow();
    } 
  })
});


// 關(guān)閉所有窗口
app.on('window-all-closed', () => {
  // electron 運(yùn)行在三個(gè)環(huán)境(win32 Windows系統(tǒng)、linux Linux系統(tǒng)、 darwin Mac系統(tǒng))
  // 此處解決的是非mac系統(tǒng),程序退出進(jìn)程 (Mac系統(tǒng)關(guān)閉app會(huì)保留在程序塢中)
  if(process.platform !== 'darwin'){
    app.quit();
  } 
})

修改 preload.js 文件

// 此文件為預(yù)加載文件,需在 main.js 文件中配置
const { ipcRenderer,contextBridge } = require('electron');

/*
* 搭建主進(jìn)程和渲染進(jìn)程的橋梁
*/ 
const mainToRender = async (res) => {
  const resData = await ipcRenderer.invoke('main-info',res);
  return resData;
};


// electronAPI 代表向渲染進(jìn)程傳遞的對(duì)象命名
contextBridge.exposeInMainWorld('electronAPI',{
  platform: process.platform,
  mainToRender,
});

修改 renderer/app.js 文件

const button = document.getElementById('btn');

button.addEventListener('click',async () => {
  // 此處的electronAPI即為預(yù)加載中傳遞的命名空間,mainToRender為傳遞過來的回調(diào)函數(shù)
  let name = document.getElementById('name');
  const res = await electronAPI.mainToRender();
  name.value = res;
})
  • 效果

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue-admin-template?添加、跳轉(zhuǎn)子頁(yè)面問題

    Vue-admin-template?添加、跳轉(zhuǎn)子頁(yè)面問題

    這篇文章主要介紹了Vue-admin-template?添加、跳轉(zhuǎn)子頁(yè)面問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • Vue中mapMutations傳遞參數(shù)方式

    Vue中mapMutations傳遞參數(shù)方式

    這篇文章主要介紹了Vue中mapMutations傳遞參數(shù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue3 defineModel的使用示例詳解

    Vue3 defineModel的使用示例詳解

    文章介紹了vue中向子組件傳值并允許修改的機(jī)制,通過defineModel實(shí)現(xiàn)雙向綁定,它返回一個(gè)ref,并且可以配置底層prop的選項(xiàng),本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2025-01-01
  • 一文帶你掌握Vue中的路由守衛(wèi)

    一文帶你掌握Vue中的路由守衛(wèi)

    路由守衛(wèi)(Route?Guards)是?Vue?Router?的一個(gè)功能,它允許我們?cè)诼酚砂l(fā)生之前執(zhí)行邏輯判斷,這篇文章主要為大家介紹了Vue中路由守衛(wèi)的具體應(yīng)用,需要的可以了解下
    2024-03-03
  • Vue如何接入hls/m3u8的直播視頻詳解

    Vue如何接入hls/m3u8的直播視頻詳解

    項(xiàng)目中有一個(gè)需求,需要實(shí)現(xiàn)直播功能,后端接口返回的是m3u8數(shù)據(jù)流,下面這篇文章主要給大家介紹了關(guān)于Vue如何接入hls/m3u8直播視頻的相關(guān)資料,需要的朋友可以參考下
    2022-07-07
  • 基于vue-video-player自定義播放器的方法

    基于vue-video-player自定義播放器的方法

    這篇文章主要介紹了基于vue-video-player自定義播放器的方法,主要是基于video.js開發(fā)的vue-video-player的使用,以及如何操作video.js中的api。需要的朋友可以參考下
    2018-03-03
  • Vue生命周期區(qū)別詳解

    Vue生命周期區(qū)別詳解

    這篇文章主要介紹了Vue生命周期區(qū)別詳解,本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • vue使用jsMind思維導(dǎo)圖的實(shí)戰(zhàn)指南

    vue使用jsMind思維導(dǎo)圖的實(shí)戰(zhàn)指南

    jsMind是一個(gè)顯示/編輯思維導(dǎo)圖的純javascript類庫(kù),其基于 html5的canvas進(jìn)行設(shè)計(jì),這篇文章主要給大家介紹了關(guān)于vue使用jsMind思維導(dǎo)圖的相關(guān)資料,需要的朋友可以參考下
    2023-01-01
  • 詳解vue路由篇(動(dòng)態(tài)路由、路由嵌套)

    詳解vue路由篇(動(dòng)態(tài)路由、路由嵌套)

    這篇文章主要介紹了詳解vue路由篇(動(dòng)態(tài)路由、路由嵌套),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-01-01
  • Vue3中如何使用Three.js詳解(包括各種樣例、常見場(chǎng)景、問題及解決方案)

    Vue3中如何使用Three.js詳解(包括各種樣例、常見場(chǎng)景、問題及解決方案)

    Three.js是一個(gè)常見的需求,Three.js是一個(gè)用于在瀏覽器中創(chuàng)建和顯示動(dòng)畫3D計(jì)算機(jī)圖形的JavaScript庫(kù),這篇文章主要介紹了Vue3中如何使用Three.js的相關(guān)資料,包括各種樣例、常見場(chǎng)景、問題及解決方案,需要的朋友可以參考下
    2025-04-04

最新評(píng)論