当前位置: 首页 > article >正文

2、electron vue3 怎么创建子窗口,并给子窗口路由传参

接上回初始化vue3 electron项目,创建完vue3 electron项目后,现在要实现在渲染进程中点击按钮创建一个新的子窗口

开始

子窗口创建操作只能在主线程内完成,而创建操作是在渲染线程触发,因此就需要进行两者间的通讯。

1、创建子窗口

background.js

//引入ipcMain
import { app, protocol,nativeImage, BrowserWindow,ipcMain } from 'electron'
...
...
// 创建提醒窗口
  function openChildWindow(e) {
    var childWin = new BrowserWindow ({
        width: 330,
        height:170,
        title:'待办提醒',
        alwaysOnTop:true,
        x:e.screenWidth-330,
        y:e.screenHeight-170,
        autoHideMenuBar: true,
        webPreferences: {
            nodeIntegration: true,
            contextIsolation: false,
        }
    })
    if (process.env.WEBPACK_DEV_SERVER_URL) {
      // 开发环境跳转路由,/remind就是配置的路由地址,并携带参数
      childWin.loadURL(process.env.WEBPACK_DEV_SERVER_URL + `#/remind?id=${e.id}`)
      if (!process.env.IS_TEST) childWin.webContents.openDevTools()
    } else {
      // 打包后跳转地址 /remind就是配置的路由地址
      createProtocol('app')
      childWin.loadURL(`app://./index.html#/remind?id=${e.id}`);
    }
    
    childWin.on("close", function(){
      childWin = null;
    })
  }
  // ipc通讯,触发创建操作
  ipcMain.on('on-open-event', (e,data) => {
    openChildWindow(JSON.parse(data))
  })

2、新建preload.js

const { ipcRenderer } = require('electron');

window.myApi = {
    openWindow: (e) => {
        console.log(e);
        ipcRenderer.send('on-open-event',JSON.stringify(e))
    },
}

3、在background.js的创建主窗口配置中引入preload.js文件

...
...
const win = new BrowserWindow({
    width: 400,
    height: 700,
    title:'待办记事本',
    frame: false, // 去掉窗口边框 // 取消默认的头部;自定义头部
    autoHideMenuBar: true, // 隐藏菜单栏
    autoHideMenuBar: true,
    icon:path.join(__dirname, '../public/logo.ico'),
    webPreferences: {
      nodeIntegration: true,
      contextIsolation: false,
      enableRemoteModule: true,
      preload: path.resolve(__dirname, "./preload.js")
    },
  })
...
...

4、在vue页面中调用,创建子窗口方法

// 打开子窗口
function open(e){
    e.screenHeight = window.screen.height
    e.screenWidth = window.screen.width
    // e是我带过去的一些参数,不需要可以不用管,自行调整一下
    window.myApi.openWindow(e)
}


http://www.kler.cn/a/320527.html

相关文章:

  • 【时间之外】IT人求职和创业应知【37】-AIGC私有化
  • 2.5D视觉——Aruco码定位检测
  • ReactPress与WordPress:一场内容管理系统的较量
  • FPGA开发-逻辑分析仪的应用-数字频率计的设计
  • Excel单元格中自适应填充多图
  • aws中AcmClient.describeCertificate返回值中没有ResourceRecord
  • 【Linux系统编程】第二十二弹---操作系统核心概念:进程创建与终止机制详解
  • LInux操作系统安装Jenkins
  • MFC-基础架构
  • 实验二十:ds1302时钟实验
  • 【MYSQL】聚合查询、分组查询、联合查询
  • CSS开发全攻略
  • 后端开发面试题7(附答案)
  • 概率论与数理统计复习笔记
  • 本地电脑基于nginx的https单向认证和双向认证(自制证书+nginx配置)保姆级
  • 一天认识一个硬件之鼠标
  • web前端(本地存储问题超过5MB不继续保存解决办法)
  • Leetcode 378. 有序矩阵中第 K 小的元素
  • TypeScript 设计模式之【建造者模式】
  • 基于python+spark的外卖餐饮数据分析系统设计与实现(含论文)-Spark毕业设计选题推荐
  • Ansible-template模块动态生成特定文件
  • Spring Boot 整合MyBatis-Plus 实现多层次树结构的异步加载功能
  • 【MATLAB源码-第176期】基于matlab的16QAM调制解调系统频偏估计及补偿算法仿真,对比补偿前后的星座图误码率。
  • 力扣(leetcode)每日一题 2306 公司命名
  • Redis数据持久化总结笔记
  • 中国蚁剑(antSword)安装使用