[electron] 程序的生命周期

electron 程序的生命周期

生命周期是一个 electron程序从启动到关闭的时间

electron 程序生命周期事件

  1. ready: app初始化完成(此时可以创建 browserWindow了)
  2. dom-ready: webContents 一个窗口中的文本加载完成
  3. did-finsh-load webContents 导航完成时触发
  4. window-all-closed 所有窗口都被关闭时触发(有默认行为,就是退出整个程序)
  5. before-quit: 关闭窗口之前触发
  6. will-quit 在窗口关闭并且应用退出时触发
  7. quit: 当所有窗口被关闭时触发

代码

javascript 复制代码
const {app, BrowserWindow} = require('electron');

app.on('ready', ()=>{
    console.log('11111111111 app ready');
    const mainwindow = new BrowserWindow({
        width: 800,
        height: 600
    });

    mainwindow.on('close', (event)=>{
        console.log('4444444444444 mainwindow close');
        event.preventDefault();
    });

    mainwindow.webContents.on('dom-ready', ()=>{
        console.log('222222222222 webContents dom-ready');
    });

    mainwindow.webContents.on('did-finish-load', ()=>{
        console.log('3333333333 webContents did-finish-load');
    });

    mainwindow.loadFile('index.html');
});

app.on('quit', ()=>{
    console.log('88888888888888 app quit');
});

app.on('window-all-closed', ()=>{
    console.log('5555555555555555 app window-all-closed');
    app.quit();
});

app.on('before-quit', ()=>{
    console.log('6666666666666666 app before-quit');
});

app.on('will-quit', ()=>{
    console.log('7777777777777 app will-quit');
});

输出结果

复制代码
11111111111 app ready
222222222222 webContents dom-ready
3333333333 webContents did-finish-load
4444444444444 mainwindow close
5555555555555555 app window-all-closed
6666666666666666 app before-quit
7777777777777 app will-quit
88888888888888 app quit

总结

目前来说就 app 的 ready 事件很重要。它用于在此事件里面创建 BrowserWindow

相关推荐
碳烤小咸鱼6 分钟前
蓝桥杯 Web 方向入门指南:从基础到实战
前端·javascript·css·蓝桥杯
inksci9 分钟前
低代码控件开发平台:飞帆中粘贴富文本的控件
前端·javascript·低代码
Mike_jia31 分钟前
一篇文章带你了解一款强大的轻量级Docker可视化管理工具---Docker-UI
前端
不懂装懂的不懂34 分钟前
【antd + vue】Tree 树形控件:默认展开所有树节点 、点击文字可以“选中/取消选中”节点
前端·javascript·vue.js
Mike_jia41 分钟前
一篇文章带你了解一款强大的IT资产管理系统---Snipe-IT
前端
WEI_Gaot42 分钟前
JS OBJECT 1 发展路线
前端·javascript
杜木至佳同志1 小时前
CSS资源汇总
前端
H5开发新纪元1 小时前
Vue3 + VantUI 多表单动态校验与提交最佳实践
前端·vue.js
小p1 小时前
写给前端的数据库mysql入门知识
前端·后端·mysql
前端花园1 小时前
swr、axios和fetch的区别
前端·面试