创建带有公共头部的Electron窗口

2024-05-26 12:52

本文主要是介绍创建带有公共头部的Electron窗口,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

创建带有公共头部的Electron窗口

创建一个公共头部的html文件

1.我们在项目根目录创建一个名为app-header的文件夹

2.在app-header创建一个文件名为header.html的文件

结构如下:

在这里插入图片描述

基本结构和脚本如下


<body>
<div class="header"><div class="left"><div class="back disabled" onclick="onBack()" id="backButton"><div class="backImg" id="backImgButton"></div></div><div class="forward disabled" onclick="onForward()" id="forwardButton"><div class="forwardImg" id="forwardImgButton"></div></div><div class="refresh" onclick="onRefresh()"><div class="refreshImg"><svg>...</svg></div></div></div><div class="center" id="centerName"></div><div class="right"><div class="close" onclick="onCloseWindow()"><svg>...<svg></div></div>
</div>
<div class="lodings" id="lodings"><svg width="50%" height="50%" viewBox="0 0 50 50">...</svg>
</div>
</body></html>
<script>function onBack() {window.electron.app.switchWindow(1);}function onForward() {window.electron.app.switchWindow(2);}function onRefresh() {window.electron.app.switchWindow(3);}//监听是否路由被改变 修改图标和点击状态window.electron.app.OnUpdateNavigationButtons((_event, args) => {if (args.canGoBack) {document.getElementById('backButton').classList.remove('disabled');document.getElementById('backImgButton').style.backgroundImage = 'url("./img/left_arrow.png")';} else {document.getElementById('backButton').classList.add('disabled');document.getElementById('backImgButton').style.backgroundImage = 'url("./img/left_arrow_tint.png")';}if (args.canGoForward) {document.getElementById('forwardButton').classList.remove('disabled');document.getElementById('forwardImgButton').style.backgroundImage = 'url("./img/right_arrow.png")';} else {document.getElementById('forwardButton').classList.add('disabled');document.getElementById('forwardImgButton').style.backgroundImage = 'url("./img/right_arrow_tint.png")';}})function onCloseWindow(){window.close()}
</script>
<style>/*省略
*/
</style>

结果运行如下:

在这里插入图片描述

创建broseWindow并嵌入broseView

根据应用传入的窗口大小,创建对应的broseWindow,并且引入公共头部文件

    let options = JSON.parse(JSON.stringify(args.options))// 窗口最小宽高if (!options.minWidth) {options.minWidth = options.width}if (!options.minHeight) {options.minHeight = options.height}options.show = false//隐藏工具栏options.autoHideMenuBar = trueoptions.frame = falseif (!options.webPreferences) {options.webPreferences = {}}options.webPreferences = Object.assign(options.webPreferences, {preload: path.join(app.getAppPath(), 'preload.js'),// preload: '../screenShotApp/app-header/header.html',webSecurity: false,})const win = new BrowserWindow(options)win.loadFile('../screenShotApp/app-header/header.html')

然后把要打开的页面放进broseView中

//应用本体const view: View = new BrowserView({webPreferences: {preload: path.join(app.getAppPath(), 'preload.js'),webSecurity: false,},})// 禁止使用 ctrl+r、  F5 等刷新win.webContents.on('before-input-event', (event, input) => {if ((input.control || input.meta) && input.key === 'r') {event.preventDefault();}if (input.key === 'f5') {event.preventDefault();}})view.webContents.loadURL('打开的页面地址')

将创建好的broseView添加到公共的broseWindows中,创建后的broseView 需要header头下偏移,不然会覆盖掉头部样式

 // view.setBounds({ x: 0, y: 45, width: options.width, height: options.height })win.on('ready-to-show', () => {win.show()win.addBrowserView(view);const bounds = win.getBounds()view.setBounds({ x: 0, y: 40, width: bounds.width, height: bounds.height - 35 })})win?.on('resize', () => {const bounds = win.getBounds()view.setBounds({ x: 0, y: 40, width: bounds.width, height: bounds.height - 35 })})win?.on('close', () => {view.webContents.close();win?.close();})

监听路由是否发生变化 改变左上角图标的状态

    // 监听子窗口路由变化view.webContents.on('did-navigate-in-page', (event, url) => {const canGoForward = view.webContents.canGoForward();const canGoBack = view.webContents.canGoBack();win.webContents?.send(channel.appUpdateNavigationButtons, { canGoForward, canGoBack, args });});BrowserWindow.getAllWindows()BrowserWindow.getFocusedWindow()

结果如下:

在这里插入图片描述

总结

本文通过将公共头部的HTML代码分离到一个独立的文件中,可以方便地在多个窗口之间共享和重用头部代码。这样的结构有助于保持代码的整洁和可维护性,同时使得界面设计更加一致。

– 欢迎点赞、关注、转发、收藏【我码玄黄】,gonghao同名

这篇关于创建带有公共头部的Electron窗口的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1004525

相关文章

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

python如何创建等差数列

《python如何创建等差数列》:本文主要介绍python如何创建等差数列的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python创建等差数列例题运行代码回车输出结果总结python创建等差数列import numpy as np x=int(in

怎么用idea创建一个SpringBoot项目

《怎么用idea创建一个SpringBoot项目》本文介绍了在IDEA中创建SpringBoot项目的步骤,包括环境准备(JDK1.8+、Maven3.2.5+)、使用SpringInitializr... 目录如何在idea中创建一个SpringBoot项目环境准备1.1打开IDEA,点击New新建一个项

如何使用Maven创建web目录结构

《如何使用Maven创建web目录结构》:本文主要介绍如何使用Maven创建web目录结构的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录创建web工程第一步第二步第三步第四步第五步第六步第七步总结创建web工程第一步js通过Maven骨架创pytho

MySQL 用户创建与授权最佳实践

《MySQL用户创建与授权最佳实践》在MySQL中,用户管理和权限控制是数据库安全的重要组成部分,下面详细介绍如何在MySQL中创建用户并授予适当的权限,感兴趣的朋友跟随小编一起看看吧... 目录mysql 用户创建与授权详解一、MySQL用户管理基础1. 用户账户组成2. 查看现有用户二、创建用户1. 基

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可

Windows的CMD窗口如何查看并杀死nginx进程

《Windows的CMD窗口如何查看并杀死nginx进程》:本文主要介绍Windows的CMD窗口如何查看并杀死nginx进程问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows的CMD窗口查看并杀死nginx进程开启nginx查看nginx进程停止nginx服务

Java中实现线程的创建和启动的方法

《Java中实现线程的创建和启动的方法》在Java中,实现线程的创建和启动是两个不同但紧密相关的概念,理解为什么要启动线程(调用start()方法)而非直接调用run()方法,是掌握多线程编程的关键,... 目录1. 线程的生命周期2. start() vs run() 的本质区别3. 为什么必须通过 st