基于electron29版本桌面应用app开发例子

基于electron29版本桌面应用app开发例子

html+js+node.js 开发模式

生成package.json文件:
yarn init --yes

npm init --yes

运行打包
yarn dev
yarn build
#==========================================
electron与electron-builder版本不兼容问题处理办法:

在package.json中scripts中添加
“postinstall”: “electron-builder install-app-deps”,
#==========================================

在VSCode的终端窗口输入:npm init --yes 则自动生成一个package.json文件
(也可以在electron_helloWorld目录下的dos窗口里输入该命令),

运行该项目:
在终端cmd输入如下命令:
electron .

OK 测试运行
yarn dev
yarn start

npm run start
npm run dev

OK 安装打包成可执行app的cmd命令:
yarn global add electron-packager
yarn global add electron-builder
yarn global add @electron-forge/cli

npm install electron-packager -g

开始打包
yarn build

npm run build

如下执行结果:
C:\Users\hsg>npm install electron-packager
added 162 packages in 7s
33 packages are looking for funding
run npm fund for details

#==========================================
#start cli cammand
cnpm install --save-dev electron @electron-forge/cli
或者
npm install --save-dev electron @electron-forge/cli
或全局安装
cnpm install -g electron @electron-forge/cli

#build cli electron-builder
打exe安装包我们使用electron-builder工具包,安装命令如下。
cnpm install --save-dev electron-builder
或者
npm install --save-dev electron-builder
或全局安装
cnpm install -g electron-builder

开始打包
yarn run build

npm run build
#==========================================
electron与electron-builder版本不兼容问题处理办法:

在package.json中scripts中添加
“postinstall”: “electron-builder install-app-deps”,
#==========================================
注意,json文件不能带注释,复制上面的文本后记得注释去掉。
修改package.json,添加一条scripts命令和build配置。
“scripts”: {
“start”: “electron-forge start”,
“postinstall”: “electron-builder install-app-deps”,
“build”: “electron-builder --win” // 打包命令
},
“devDependencies”: {
“@electron-forge/cli”: “^6.2.1”,
“electron”: “^25.4.0”, //max=29
“electron-builder”: “^24.6.3” //max=25
},
“dependencies”: {
“cesium”: “^1.112.0”,
“@electron-forge/cli”: “^6.2.1”
},
// electron-builder配置
“build”: {
“productName”: “我的应用”, // 安装应用后桌面名称
“directories”: {
“output”: “out” // 输出的文件目录
},
“win”: {
“icon”: “./ico/logo.ico”, // 安装的图标
“target”: [
{
“target”: “nsis”,
“arch”: [
“x64”,
“ia32”
]
}
]
},
“nsis”: {
“oneClick”: false,
“allowElevation”: true,
“allowToChangeInstallationDirectory”: true,
“installerIcon”: “./ico/logo.ico”,
“uninstallerIcon”: “./ico/logo.ico”,
“installerHeaderIcon”: “./ico/logo.ico”,
“createDesktopShortcut”: true,
“createStartMenuShortcut”: true,
“shortcutName”: “我的应用”
}
}
#==========================================
#如果报错,可以采用node_modules目录删除,重新下载依赖包
cnpm install

#cesium安装cmd命令: //OK
cnpm install cesium --save

(三). Remote安装和使用
安装:在命令提示符下,输入:
cnpm install ‘@electron/remote’
或者
npm install ‘@electron/remote’

使用示例:
在主进程中:
const remote = require(‘@electron/remote/main’)
remote.initialize()
remote.enable(mainWindow.webContents)

在渲染进程中:
const remote = require(‘@electron/remote’)
remote. remote.dialog.showOpenDialog() //示例

“extractResources”: {
“from”: “./resource/db/”,
“to”: “db”
},

package.json文件内容:

{"name": "pg-electron","version": "1.0.0","main": "main.js","repository": "https://gitee.com/hsg77/pg-electron.git","author": "'hsg77' <'qqId@qq.com'>","license": "MIT","scripts": {"test": "echo \"Error: no test specified\" && exit 1","postinstall": "electron-builder install-app-deps","dev": "electron-forge start","start": "electron-forge start","build": "electron-builder --win","electron:build":"electron-builder --win","build:windows": "node_modules/.bin/electron-builder -w"},"keywords": [],"devDependencies": {"@electron-forge/cli": "^6.2.1","electron": "^29.0.0","electron-builder": "^23.0.0","electron-updater": "^5.2.1"},"dependencies": {"@electron-forge/cli": "^6.2.1","cesium": "^1.112.0","sqlite3": "^5.1.6"},"build": {"productName": "我的应用","appId": "com.cwgis.pg.electron","copyright": "cwgis 版板所有","directories": {"output": "out"},"win": {"icon": "./ico/logo.ico","target": [{"target": "nsis","arch": ["ia32"]}]},"nsis": {"oneClick": false,"allowElevation": true,"allowToChangeInstallationDirectory": true,"installerIcon": "./ico/logo.ico","uninstallerIcon": "./ico/logo.ico","installerHeaderIcon": "./ico/logo.ico","createDesktopShortcut": true,"createStartMenuShortcut": true,"shortcutName": "我的应用"}}
}

在这里插入图片描述

本blog地址:https://blog.csdn.net/hsg77
本blog源代码地址:https://gitee.com/hsg77/pg-electron.git

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/763144.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

解决在 yolov8 训练自己的数据集时,matplotlib 中文乱码问题【woodwhales.cn】

为了更好的阅读体验&#xff0c;建议移步至笔者的博客阅读&#xff1a;解决在 yolov8 训练自己的数据集时&#xff0c;matplotlib 中文乱码问题 在 yolov8 训练自己的数据集时&#xff0c;如果 class 字典使用了中文&#xff0c;则在训练过程中会出现形如下面的警告&#xff1a…

面试官:(...)扩展运算符是深拷贝吗?

一、情景再现 金三银四&#xff0c;最近找工作的小伙伴是扑面而来&#xff0c;这其中少不了我的好朋友张某某同学&#xff0c;我们‘相依为命’&#xff0c;我经常开导他&#xff0c;这不最近的一次面试中他就遇到这样一个考题&#xff1a; 面试官&#xff1a;&#xff08;...&…

亚远景科技-什么是Hardware SPICE(HW SPICE)硬件过程改进与能力判定模型 ?

intacs硬件SPICE&#xff08;Software Process Improvement and Capability Determination for Hardware Engineering&#xff09;是一种针对硬件工程领域的过程改进和能力评估模型&#xff0c;旨在支持电子硬件开发。它是基于SPICE&#xff08;软件过程改进和能力评估&#xf…

【NumPy数值计算基础】NumPy数组的基本操作

目录 一、数组的索引和切片&#xff08;一&#xff09;数组的索引&#xff08;二&#xff09;数组的切片 二、数组的变换&#xff08;一&#xff09;数组转置&#xff08;二&#xff09;数组重塑&#xff08;三&#xff09;数组合并&#xff08;四&#xff09;数组分割 三、数组…

力扣242. 有效的字母异位词

思路&#xff1a;字母相互抵消的思路&#xff0c;本题字符串中只包含小写字母26位&#xff0c;那就新建record数组int[26]&#xff0c;下标0-25&#xff0c;代表小写字母a-z, 需要通过 某字符减a 来达到这一目的&#xff1b; class Solution {public boolean isAnagram(String…

ginblog博客系统/golang+vue

ginblog博客系统 前台&#xff1a; 后台&#xff1a; Gitee的项目地址&#xff0c;点击进入下载 注意&#xff1a; 数据库文件导入在model里面&#xff0c;直接导入即可。 admin和front前后台系统记住修改https里的地址为自己的IP地址&#xff1a; front同上。

直播弹幕系统设计

设计一个直播弹幕系统需要考虑到系统的实时性、可扩展性、高可用性以及数据持久性等多个方面。 1. 功能需求分析 实时性&#xff1a;弹幕消息需要尽可能即时地显示在直播视频上。高吞吐量&#xff1a;系统需要处理大量用户同时发送的弹幕。数据的持久化&#xff1a;如果需要保…

医学预测变量筛选的几种方法(R语言版)

医学预测变量筛选的几种方法&#xff08;R语言版&#xff09; 预测变量筛选是机器学习中的一个重要环节&#xff0c;它可以帮助我们识别出与目标变量最相关的特征&#xff0c;从而提高模型的预测精度和解释性。在医学领域&#xff0c;预测变量筛选可以用于疾病诊断、预后评估、…

两数之和(python)

官方题目描述&#xff1a; 给定一个整数数组 nums 和一个整数目标值 target&#xff0c;请你在该数组中找出 和为目标值 target 的那 两个 整数&#xff0c;并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是&#xff0c;数组中同一个元素在答案里不能重复出现…

JSONP 实现跨域请求案例

后端使用 express 搭建&#xff0c;案例代码如下&#xff1a; const express require(express)const app express() const PORT 3000app.get(/data, (req, res) > {const jsonData {name: Alan,age: 666,city: GD}const callback req.query.callback // 获取前端中的回…

婴儿浴盆CE认证EN17072检测报告

婴幼儿浴盆浴缸儿童护理用品CE认证EN17072测试报告 什么是婴儿浴盆&#xff1f; 婴儿浴盆是专为年幼的宝宝洗澡而设计的用品。您可以用婴儿浴盆将宝宝洗得干干净净&#xff0c;又不必过多担心安全问题。有些浴盆贴心的细节设计还能增加洗澡的乐趣。 大多数的婴儿浴盆尺寸适用…

布隆过滤器原理介绍和典型应用案例

整理自己过去使用布隆过滤器的应用案例和理解 基本介绍 1970年由布隆提出的一种空间效率很高的概率型数据结构&#xff0c;它可以用于检索一个元素是否在一个集合中&#xff0c;由只存0或1的位数组和多个hash算法, 进行判断数据 【一定不存在或者可能存在的算法】 如果这些…

【机器学习300问】43、回归模型预测效果明明很好,为什么均方根误差很大?

一、案例描述 假设我们正在构建一个房地产价格预测模型&#xff0c;目标是预测某个城市各类住宅的售价。模型基于大量房屋的各种特征&#xff08;如面积、地段、房龄、楼层等&#xff09;进行训练。 回归模型在大部分情况下对于住宅价格预测非常精准&#xff0c;用户反…

java Flink(四十三)Flink Interval Join源码解析以及简单实例

背景 之前我们在一片文章里简单介绍过Flink的多流合并算子 java Flink&#xff08;三十六&#xff09;Flink多流合并算子UNION、CONNECT、CoGroup、Join 今天我们通过Flink 1.14的源码对Flink的Interval Join进行深入的理解。 Interval Join不是两个窗口做关联&#xff0c;…

阿里云通过脚本直接修改SSH配置来允许root登录并启用密码认证

看起来你想要通过脚本直接修改SSH配置来允许root登录并启用密码认证。然而&#xff0c;PermitRootLogin和PasswordAuthentication这两个指令是/etc/ssh/sshd_config文件中的配置选项&#xff0c;不能直接通过set命令在bash脚本中设置。set命令在shell脚本中用于设置或取消设置s…

2.Redis有五种主要的数据类型

Redis有五种主要的数据类型 String&#xff08;字符串&#xff09;&#xff1a;String类型是最简单的数据类型&#xff0c;可以存储任意类型的数据&#xff0c;例如整数、浮点数、字符串等。String类型支持一些基本的操作&#xff0c;如设置值、获取值、增减值等。 Hash&#…

论文笔记:Llama 2: Open Foundation and Fine-Tuned Chat Models

导语 Llama 2 是之前广受欢迎的开源大型语言模型 LLaMA 的新版本&#xff0c;该模型已公开发布&#xff0c;可用于研究和商业用途。本文记录了阅读该论文的一些关键笔记。 链接&#xff1a;https://arxiv.org/abs/2307.09288 1 引言 大型语言模型&#xff08;LLMs&#xff…

cesium Clock JulianDate 日照分析

cesium在初始化的时候会自动把Clock对象挂载到容器上Clock内部以JulianDate维护时间&#xff0c;比北京时间慢8个小时&#xff0c;想显示北京时间需要计算时差JulianDate的日期部分和秒数部分是分开的 julianDayNumber&#xff1a;指整数天&#xff0c;记录从公元前4713年正午以…

GO 语言基础学习记录

一&#xff1a;声明变量 在golang语言中声明变量的方式 package main import "fmt" func main() { var a int 3 //关键字 var 变量名 变量指定类型 变量值 var b int //关键字 var 变量名 变量指定类型(注意:当变量没赋值时是按照变量…

【蓝桥杯】第15届蓝桥杯青少组stema选拔赛C++中高级真题答案(20240310)

一、选择题 第 1 题 第 2 题 表达式1000/3的结果是( A )。 A.333 B.333.3 C.334 D.333.0 第 3 题 下列选项中&#xff0c;判断a等于1并且b等于1正确的表达式是( B )。 A.!((a!1)&&(b!1)) B.!((a!1)||(b!1)) C.!(a1)&&(b1) D.(a1)&&(b1) 【解析】 A…