摘要:一安裝配置環(huán)境一種桌面應(yīng)用程序運行時,把和合并到一個多帶帶的運行時里面,很適合開發(fā)桌面形式的應(yīng)用程序,通過它提供了通常瀏覽器所不能提供的能力。
一、安裝配置環(huán)境
Electron(一種桌面應(yīng)用程序運行時),Electron 把 Chromium 和 Node 合并到一個多帶帶的運行時里面,很適合開發(fā)桌面 web 形式的應(yīng)用程序,通過Node它提供了通常瀏覽器所不能提供的能力。
首先需要在電腦進行安裝配置Node環(huán)境,下載Nodejs,安裝的過程像安裝QQ一樣簡單
通過npm全局安裝electron
npm install electron -g
這樣你就可以在電腦的任意位置進行你想要的操作了
進入你要打包的H5網(wǎng)頁的根目錄
二、操作項目進入項目目錄需要先在根目錄進行創(chuàng)建兩個文件,分別為package.json、main.js,這兩個文件與你項目的index.html在同一個文件內(nèi)
package.json內(nèi)的文件內(nèi)容
{ "name": "app-name", "version": "0.1.0", "main": "main.js" }
main.js內(nèi)的內(nèi)容
const { app, BrowserWindow } = require("electron") const path = require("path") const url = require("url") // Keep a global reference of the window object, if you don"t, the window will // be closed automatically when the JavaScript object is garbage collected. let win function createWindow() { // Create the browser window. win = new BrowserWindow({ width: 800, height: 600 }) // and load the index.html of the app. win.loadURL( url.format({ pathname: path.join(__dirname, "index.html"), protocol: "file:", slashes: true, }), ) // Open the DevTools. // win.webContents.openDevTools() // Emitted when the window is closed. win.on("closed", () => { // Dereference the window object, usually you would store windows // in an array if your app supports multi windows, this is the time // when you should delete the corresponding element. win = null }) } // This method will be called when Electron has finished // initialization and is ready to create browser windows. // Some APIs can only be used after this event occurs. app.on("ready", createWindow) // Quit when all windows are closed. app.on("window-all-closed", () => { // On macOS it is common for applications and their menu bar // to stay active until the user quits explicitly with Cmd + Q if (process.platform !== "darwin") { app.quit() } }) app.on("activate", () => { // On macOS it"s common to re-create a window in the app when the // dock icon is clicked and there are no other windows open. if (win === null) { createWindow() } }) // In this file you can include the rest of your app"s specific main process // code. You can also put them in separate files and require them here.
下載需要的打包插件工具 electron-packag
npm install electron-package -g
最后一步進行打包操作,這塊比較代碼比較長
electron-package . (生成exe文件的名字) --win --out (打包完文件夾的名字) -arch=×64 --electronVersion (electron的版本號) --overwrite --ignore=node_modules即可完成打包
例如:我的項目需要進行打包的操作為:
electron-packager . miaotong --win --out presenterTool --arch=x64 --electronVersion 3.0.4 --overwrite --ignore=node_modules
注意:--electronVersion的版本號必須和你第一步安裝的electron版本一致,如果不確定版本可以輸入命令進行查看
cmd----->electron -v 終端會輸出你當(dāng)前全局安裝electron的版本號,當(dāng)然這個操作也是你驗證electron有沒有安裝成功的方法
至此就看自己的操作和運氣了,上面的長串指令執(zhí)行完成之后,在你的項目下會生成一個presenterTool文件夾,一級一級點擊進去,會看到一個exe文件,點擊試試吧
三、存在的問題目前打包出來的exe文件比較大,這部分還需要一個精簡操作,等我找到靠譜的解決辦法,再更新一下這個文章吧!
四、上圖項目展示:
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/53074.html
摘要:在菜單中,我想點擊子菜單打開一個網(wǎng)站,那么就可以用到方法,則會在默認(rèn)瀏覽器中打開打包應(yīng)用其實將程序打包成桌面應(yīng)用才是比較麻煩的事。 前言 Electron 是一個搭建跨平臺桌面應(yīng)用的框架,僅僅使用 JavaScript、HTML 以及 CSS,即可快速而容易地搭建一個原生應(yīng)用。這對于想要涉及其他領(lǐng)域的開發(fā)者來說是一個非常大的福利。 項目介紹 倉庫地址:lin-xin/calculato...
摘要:在開發(fā)項目時,可以先用網(wǎng)頁的形式開發(fā)項目,等到網(wǎng)頁項目部分差不多完成后,再注入中,開發(fā)網(wǎng)頁項目部分和窗體部分的交互在中使用后,將不會打包有關(guān)的代碼 electron是一兩年前挺火的一個框架本質(zhì)上是一個瀏覽器,但是集成了很多windows系統(tǒng)的功能,讓前端開發(fā)也可以直接操作windows的窗體,做成一個實打?qū)嵉淖烂孳浖?團隊主要的技術(shù)棧是react,所以考慮用react開發(fā),方便維護。 ...
摘要:話不多說,進入正題一安裝為了方便你以后的使用,建議全局安裝。怎么安裝就不廢話了,不會的去官網(wǎng),安裝好之后也安裝一個專用的打包工具,以方便我們后面打包的時候使用。有些只能在該事件發(fā)生后才能被使用。 也許你不甘心只寫網(wǎng)頁,被人叫做他會寫網(wǎng)頁,也許你有項目需求,必須寫桌面應(yīng)用,然而你只會前端,沒關(guān)系。網(wǎng)上的教程很多,但是很少有能說的淺顯易懂的,我盡力將electron打包應(yīng)用說的清晰明了,希...
摘要:話不多說,進入正題一安裝為了方便你以后的使用,建議全局安裝。怎么安裝就不廢話了,不會的去官網(wǎng),安裝好之后也安裝一個專用的打包工具,以方便我們后面打包的時候使用。有些只能在該事件發(fā)生后才能被使用。 也許你不甘心只寫網(wǎng)頁,被人叫做他會寫網(wǎng)頁,也許你有項目需求,必須寫桌面應(yīng)用,然而你只會前端,沒關(guān)系。網(wǎng)上的教程很多,但是很少有能說的淺顯易懂的,我盡力將electron打包應(yīng)用說的清晰明了,希...
摘要:當(dāng)一個實例被銷毀后,相應(yīng)的渲染進程也會被終止。之所以命名為,主要是為了與主進程這個概念對應(yīng)。部分在事件觸發(fā)后才能使用。當(dāng)全部窗口關(guān)閉時退出。主進程接收到消息并處理之后,會返回處理結(jié)果。 簡介 Electron 是一個可以使用 Web 技術(shù)如 JavaScript、HTML 和 CSS 來創(chuàng)建跨平臺原生桌面應(yīng)用的框架。借助 Electron,我們可以使用純 JavaScript 來調(diào)用豐...
閱讀 3547·2021-09-22 15:50
閱讀 3245·2019-08-30 15:54
閱讀 2757·2019-08-30 14:12
閱讀 3067·2019-08-30 11:22
閱讀 2089·2019-08-29 11:16
閱讀 3584·2019-08-26 13:43
閱讀 1198·2019-08-23 18:33
閱讀 930·2019-08-23 18:32