electron開發百度桌面應用demo及如何打包應用

1.開發入口文件main.js

1-1 加載百度URL

const { app, BrowserWindow, nativeImage } = require('electron')
const path = require('node:path')const createWindow = () => {const win = new BrowserWindow({width: 800,height: 600,})//加載百度URLwin.loadURL('https://www.baidu.com/')
}app.whenReady().then(() => {// 調用 createWindow 函數,該函數的作用是創建一個新的瀏覽器窗口createWindow()
})

1-2 設置窗口圖標

1-2-1 根目錄中添加ico圖標,如圖


1-2-2 入口文件main.js中設置icon

 const appIcon = nativeImage.createFromPath(path.join(__dirname, 'baidu.ico'))const win = new BrowserWindow({width: 800,height: 600,icon: appIcon,})

1-3 入口文件完整實例代碼

const { app, BrowserWindow, nativeImage } = require('electron')
const path = require('node:path')const createWindow = () => {const appIcon = nativeImage.createFromPath(path.join(__dirname, 'baidu.ico'))const win = new BrowserWindow({width: 800,height: 600,icon: appIcon,})// 設置菜單不可見win.menuBarVisible = false;//加載指定路徑的文件//win.loadFile('index.html')// 加載指定的 URLwin.loadURL('https://www.baidu.com/')
}app.whenReady().then(() => {// 調用 createWindow 函數,該函數的作用是創建一個新的瀏覽器窗口createWindow()
})

2.啟動項目測試

npm run start

3.使用 Electron Forge打包應用

3-1 安裝Electron Forge ,并使用現成的轉化腳本將項目導入至 Electron Forge

npm install --save-dev @electron-forge/cli
npx electron-forge import

3-1-1 安裝完成檢查package.json配置是否如下

3-2 package.json中添加打包應用圖標配置

 "config": {"forge": {"packagerConfig": {"icon": "./logo.ico"}}},

3-3 打包應用

npm run make

3-4 解決打包錯誤

3-4-1?package.json中添加makers配置

 "config": {"forge": {"packagerConfig": {"icon": "./logo.ico"},"makers": [{"name": "@electron-forge/maker-squirrel","platforms": ["win32"]},{"name": "@electron-forge/maker-zip","platforms": ["win32"]}]}},

3-5 重新打包

npm run make

3-5-1 打包完成

打包完成看到一個?out?文件夾,其中包括可分發文件與一個包含其源碼的文件夾,證明打包成功。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/81687.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/81687.shtml
英文地址,請注明出處:http://en.pswp.cn/web/81687.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

LiveGBS海康、大華、宇視、華為攝像頭GB28181國標語音對講及語音喊話:攝像頭設備與服務HTTPS準備

LiveGBS海康、大華、宇視、華為攝像頭GB28181國標語音對講及語音喊話:攝像頭設備與服務HTTPS準備 1、背景2、準備工作2.1、服務端必備條件(注意事項)2.2、語音對講設備準備2.2.1、大華攝像機2.2.2、海康攝像機 3、開啟音頻并開始對講4、相關問…

JWT安全:假密鑰.【簽名隨便寫實現越權繞過.】

JWT安全:假密鑰【簽名隨便寫實現越權繞過.】 JSON Web 令牌 (JWT)是一種在系統之間發送加密簽名 JSON 數據的標準化格式。理論上,它們可以包含任何類型的數據,但最常用于在身份驗證、會話處理和訪問控制機制中發送有關用戶的信息(“聲明”)。…

# Python 語音助手本地的ollama實現

項目簡介 本項目是一個基于 Python 的智能語音助手,集成了語音錄制、語音識別、AI對話和語音合成功能。用戶可以通過語音與本地部署的 Ollama 大模型進行自然對話。 技術架構 核心功能模塊 語音錄制 - 使用 sounddevice 錄制用戶語音語音識別 - 使用 faster-whi…

第1章第1節:安全運維基礎思維與體系建設-安全運維的定義與核心目標

🎯 實戰目標: 理解“安全運維”與傳統運維的本質區別 掌握安全運維的核心目標與價值定位 建立以“持續可控、可視可審、自動響應”為核心的思維框架 📖 背景知識: ? 傳統運維 vs 安全運維 傳統運維關注:系統穩定、…

LNMP 架構部署

目錄 一、基于授權的訪問控制 (一)功能簡介 (二)配置步驟 二、基于客戶端的訪問控制 (一)功能簡介 (二)配置步驟 三、Nginx 虛擬主機 (一)基于域名的…

JVM與JMM深度解析:從Java 8到Java 21的演進

文章目錄 第一部分:JVM基礎概念與架構JVM是什么?JVM整體架構運行時數據區類加載機制執行引擎 第二部分:Java內存模型(JMM)什么是Java內存模型JMM的核心問題主內存與工作內存內存間交互操作重排序與happens-before原則v…

Docker 掛載卷并保存為容器

1 創建docker容器 使用鏡像osrf/ros:humble-desktop-full-jammy創建并運行容器 sudo docker run -it --name ros2_humble osrf/ros:humble-desktop-full-jammy /ros_entrypoint.sh bash docker run -it -v d:\docker\ros2_humble:/root/ros2_ws osrf/ros:humble-desktop-fu…

無人機飛手共享接單平臺

2025年,無人機已不再是“黑科技”的代名詞。從農田噴灑到外賣配送,從航拍攝影到醫療急救,無人機正以驚人的速度滲透我們的生活。而在這場變革中, “無人機飛手共享接單平臺” 成為連接技術與需求的核心樞紐。它不僅讓專業飛手輕松…

【Web應用】若依框架:基礎篇07功能詳解-定時任務

文章目錄 ?前言?一、講解過程?二、動手實操?總結 標題詳情作者JosieBook頭銜CSDN博客專家資格、阿里云社區專家博主、軟件設計工程師博客內容開源、框架、軟件工程、全棧(,NET/Java/Python/C)、數據庫、操作系統、大數據、人工智能、工控、網絡、程序…

8.8 Primary ODSA service without ODSA Portal

主要ODSA服務(不使用ODSA門戶) 以下場景描述如下情況: ? 主ODSA客戶端應用程序被允許用于該類型的主設備,且對終端用戶啟用(已授權)。 ? 服務提供商(SP)能夠在不涉及ODSA門戶Web服…

深度檢測與動態透明度控制 - 基于Babylon.js的遮擋檢測實現解析

首先貼出實現代碼: OcclusionFader.ts import { AbstractEngine, Material, type Behavior, type Mesh, type PBRMetallicRoughnessMaterial, type Scene } from "babylonjs/core"; import { OcclusionTester } from "../../OcclusionTester"…

openssl 使用生成key pem

好的,以下是完整的步驟,幫助你在 Windows 系統中使用 OpenSSL 生成私鑰(key)和 PEM 文件。假設你的 openssl.cnf 配置文件位于桌面。 步驟 1:打開命令提示符 按 Win R 鍵,打開“運行”對話框。輸入 cmd&…

音視頻之視頻壓縮及數字視頻基礎概念

系列文章: 1、音視頻之視頻壓縮技術及數字視頻綜述 一、視頻壓縮編碼技術綜述: 1、信息化與視頻通信: 什么是信息: 眾所周知,人類社會的三大支柱是物質、能量和信息。具體而言,農業現代化的支柱是物質&…

傳統數據表設計與Prompt驅動設計的范式對比:以NBA投籃數據表為例

引言:數據表設計方法的演進 在數據庫設計領域,傳統的數據表設計方法與新興的Prompt驅動設計方法代表了兩種截然不同的思維方式。本文將以NBA賽季投籃數據表(shots)的設計為例,深入探討這兩種方法的差異、優劣及適用場景。隨著AI技術在數據領…

XCTF-web-mfw

發現了git 使用GitHack下載一下源文件&#xff0c;找到了php源代碼 <?phpif (isset($_GET[page])) {$page $_GET[page]; } else {$page "home"; }$file "templates/" . $page . ".php";// I heard .. is dangerous! assert("strpos…

Prompt Tuning與自然語言微調對比解析

Prompt Tuning 與輸入提示詞自然語言微調的區別和聯系 一、核心定義與區別 維度Prompt Tuning(提示微調)輸入提示詞自然語言微調本質優化連續向量空間中的提示嵌入(不可直接閱讀)優化離散自然語言文本(人類可理解)操作對象模型輸入嵌入層的連續向量(如WordEmbedding)自…

LVS的DR模式部署

目錄 一、引言&#xff1a;高并發場景下的流量調度方案 二、LVS-DR 集群核心原理與架構設計 &#xff08;一&#xff09;工作原理與數據流向 數據包流向步驟3&#xff1a; &#xff08;二&#xff09;模式特性與53網絡要求 三、實戰配置&#xff1a;從9環境搭建到參數調整…

8種常見數據結構及其特點簡介

一、8種常見數據結構 1. 數組&#xff08;Array&#xff09; 簡介&#xff1a;數組是有序元素的序列&#xff0c;連續內存塊存儲相同類型元素&#xff0c;通過下標直接訪問。數組會為存儲的元素都分配一個下標&#xff08;索引&#xff09;&#xff0c;此下標是一個自增連續的…

通過mailto:實現web/html郵件模板喚起新建郵件并填寫內容

一、背景 在實現網站、html郵件模板過程中&#xff0c;難免會遇到需要通過郵箱向服務提供方發起技術支持等需求&#xff0c;因此&#xff0c;我們需要通過一個功能&#xff0c;能新建郵件并提供模板&#xff0c;提高溝通效率 二、mailto協議配置說明 參數描述mailto:nameema…

好用但不常用的Git配置

參考文章 文章目錄 tag標簽分支新倉庫默認分支推送 代碼合并沖突處理默認diff算法 tag標簽 默認是以字母順序排序&#xff0c;這會導致一些問題&#xff0c;比如0.5.101排在0.5.1000之后。為了解決這個問題&#xff0c;我們可以把默認排序改為數值排序 git config --global t…