2 - Electron 核心概念

news/2024/7/10 0:39:37 标签: vue, electron, node.js

electron-%E6%A0%B8%E5%BF%83%E6%A6%82%E5%BF%B5">  Electron 核心概念

主进程

  • 通过Node.js、Electron提供的API与系统底层打交道
  • 启动项目时运行的 main.js 脚本就是我们说的主进程。
  • 在主进程运行的脚本可以以创建 Web 页面的形式展示 GUI。
  • 主进程只有一个

渲染进程

  • 每个 Electron 的页面都在运行着自己的进程,这样的进程称之为渲染进程(基于Chromium的多进程结构)。
  • 创建一个窗体都会创建一个渲染进程,每个web页面运行在它自己的渲染进程中,每个渲染进程是独立的。每个BrowserWindow实例都在自己的渲染进程中运行, 当BrowserWindow实例被销毁后, 相应的渲染进程也会被终止
运行项目找到package.json的入口文件(属性main的值)即为主进程,加载入口文件 实例化BrowserWindow,加载本地index.html即为渲染进程,可以有多个渲染进程

主进程 - 生命周期

//所有窗口都关闭
app.on("window-all-closed", () => {
  // 对于 MacOS 系统 -> 关闭窗口时,不会直接推出应用
  if (process.platform !== "darwin") {
    app.quit(); //让app彻底关闭
  }
});

app.whenReady().then(() => {
  createWindow();
  app.on("activate", () => {
    // 在macOS上,当单击dock图标并且没有其他窗口打开时,
    // 通常在应用程序中重新创建一个窗口。
    if (BrowserWindow.getAllWindows().length === 0) {
      createWindow();
    }
  });
});

主进程和渲染进程通信

主进程 接收与返回

//main.js 主进程文件、
const createWindow = () => {
  const win = new BrowserWindow({
    width: 1000,
    height: 600,
    webPreferences: {
      // 设置预加载脚本路径  注意:预加载文件属于渲染进程哦
      preload: path.join(__dirname, "./preload.js"),
    },
  });
  win.loadFile("index.html");
};


ipcMain.handle("send-event", (event, msg) => {
  console.log("msg", msg); //主进程 接收 渲染进程的信息
  return msg; //返回给渲染进程
});

 渲染进程 发送与打印

//preload.js 预加载文件
const { ipcRenderer, contextBridge } = require("electron");
const handleSend=async()=>{
   let fallback=ipcRenderer.invoke('send-msg','这是渲染进程 -> 主进程的内容') 
   console.log(fallback);//主进程返回过来的内容
}
//通过exposeInMainWorld把方法绑在window上
contextBridge.exposeInMainWorld('myApi',{ 
    handleSend,
})

.html调用

<button id="btn">Send</button>
<script>
    document.getElementById('btn').addEventListener('click', function(){
        window.myApi.handleSend()
    })
</script>

渲染进程如何使用 Node 模块 

方法一  

20版本所有渲染进程都采用沙盒模式,不允许在preload中使用node模块了,注意查看自己的版本。

//main.js
const createWindow = () => {
  const win = new BrowserWindow({
    width: 1000,
    height: 600,
    webPreferences: {
      preload:path.resolve(__dirname, "./preload.js"), //配置预加载文件 
    },
  });
//preload.js
const {contextBridge}=require('electron')
//通过exposeInIsolatedWorld将process.platform注到window对象上
contextBridge.exposeInIsolatedWorld('myApi',{
    platform: process.platform,
})

//index.html 渲染进程 就可以访问到
console.log(window.myApi.platform);

方法二

尽量不要用,不安全!!!!自己写dome可以玩玩看

当我们想在index.html(渲染进程)中想访问文件时

<script>
    const fs=require('fs')
    console.log(fs);
</script>

require是nodejs环境语法,可以在主进程中使用,但不能渲染进程中使用 

 打通隔离

const createWindow = () => {
  const win = new BrowserWindow({
    width: 1000, 
    height: 600, 
    webPreferences:{
        nodeIntegration: true, //集成node
        contextIsolation: false,//打通隔离,主进程和渲染进程都可以使用node
    }
  });


http://www.niftyadmin.cn/n/5262007.html

相关文章

(0-1)分布

假设离散型随机变量X只可能取到0、1两个值&#xff0c;它的分布律为&#xff1a; &#xff0c;其中&#xff0c; 那么称X服从参数为p的0-1分布&#xff0c;也叫两点分布。 其实上面公式就是将下面两个式子写在一起&#xff1a;

算法Day34 找数游戏

找数游戏 Description 小明有一个整数数组nums&#xff0c;他希望找出并返回能被三整除的元素最大和。你能找出符合要求的数。 Input 输入整数数组nums的各个元素&#xff0c;数字间用“,”相隔。 1≤nums.length≤10 1≤nums[i]≤10^4 Output 输出能被3整除的元素最大和&…

每日一算法:深度优先算法

深度优先搜索&#xff08;Depth-First Search&#xff0c;简称DFS&#xff09;是一种用于遍历或搜索树或图的算法。如其名&#xff0c;该算法深入到可能的分支上&#xff0c;直到目标节点被找到或者已经没有其他节点可以继续深入&#xff0c;此时算法回溯到上一节点&#xff0c…

GPIO的使用--滴答定时器--pir人体红外传感器

目录 一、滴答定时器的使用与原理 1、定义 2、原理 &#xff08;1&#xff09;向上计数​编辑 &#xff08;2&#xff09;向下计数 &#xff08;3&#xff09; 代码流程 a、配置滴答时钟唤醒频率 b、滴答时钟中断函数 &#xff08;4&#xff09;结果 3、优化-->寄存…

磁盘空间分析工具你知道几个!8个易学易用的磁盘分析工具,让你对硬盘知根知底

以下是我对可用磁盘空间分析工具(有时称为存储分析器)的首选列表。在我的电脑上试用了其中几个应用程序后,我可以确认这里列出的应用程序是100%免费使用的,并且在弄清楚是什么填满了硬盘、闪存驱动器或外部驱动器中做了很多工作,其中一些甚至允许你直接从程序中删除文件。…

第14节:Vue3 简化用法<script setup>

下面是一个示例&#xff0c;演示了如何在UniApp中使用 <template> <view> <text>{{ message }}</text> <button click"changeMessage">点击改变文本</button> </view> </template> <script setup> imp…

H5开发App应用程序的常见问题以及解决方案

Hello大家好&#xff0c;我是咕噜铁蛋&#xff0c;天冷记得添衣&#xff0c;ok话说回来H5开发成为了一种流行的方式来构建跨平台的移动应用程序。然而&#xff0c;在H5开发App应用程序的过程中&#xff0c;我们常常会遇到一些问题&#xff0c;这些问题可能涉及性能、兼容性、用…

【字符串】ABC324E

退役啦&#xff0c;接下来的博客全是图一乐啦 E - Joint Two Strings 题意 思路 统计两个指针的方案数一定是枚举一个&#xff0c;统计另一个 然后因为拼起来之后要包含 t 这个字符串&#xff0c;隐隐约约会感觉到和前缀后缀子序列有关 考虑预处理每个 s[i] 的最长公共前…