基於 Vue 的 Electron 項目搭建

来源:https://www.cnblogs.com/ting-hui/archive/2020/07/20/13345000.html
-Advertisement-
Play Games

本文將介紹如何從零搭建一個集成vue的electron項目,以及搭建過程中可能會出現的問題及其解決方法 ...


Electron 應用技術體系推薦

目錄結構

demo(項目名稱)
├─ .electron-vue(webpack配置文件)
│  └─ build.js(生產環境構建代碼) 
|  └─ dev-client.js(熱載入相關)
│  └─ dev-runner.js(開發環境啟動入口)
│  └─ webpack.main.config.js(主進程配置文件)
│  └─ webpack.renderer.config.js(渲染進程配置文件)
│  └─ webpack.web.config.js
├─ build(是文件打包使用的)
│  └─ win-unpacked/
│  │  ├─ locales(地區語言資源包)
│  │  ├─ resources(地區語言資源包)
│  │  ├─ *.dll(動態鏈接庫)
├─ dist(打包後的文件資源)
│  ├─ electron
|  ├─ web
├─ node_modules/(依賴目錄)
├─ src(源碼)
│  ├─ main(主進程)
│  │  └─ index.dev.js(捆綁index.js)
│  │  └─ index.js(主進程的進程JS)
│  ├─ renderer(渲染進程)
│  │  ├─ assets/(放置靜態資源,如圖片,視頻,靜態配置)
│  │  ├─ components/(放置vue頁面)
│  │  ├─ router/(放置頁面路由)
│  │  ├─ store/(放置公共模塊,如vuex)
│  │  ├─ App.vue
│  │  └─ main.js
│  └─ index.ejs
├─ static/(靜態文件)
├─ test
│  ├─ e2e
│  │  ├─ specs/
│  │  ├─ index.js
│  │  └─ utils.js
│  ├─ unit
│  │  ├─ specs/
│  │  ├─ index.js
│  │  └─ karma.config.js
│  └─ .eslintrc#全局配置文件
├─ .babelrc
├─ .eslintignore
├─ .eslintrc.js
├─ .gitignore
├─ package.json
└─ README.md

環境搭建

預設有 node 環境.

  1. 先安裝 electron vue vue-cli,因為electron-vue 中有內置 webpack ,無需再裝一個獨立的webpack

    npm install -g electron
    npm install -g vue
    npm install -g vue-cli
    
  2. 創建一個空文件夾,DOS命令視窗進入該文件夾位置,初始化一個 electron-vue 項目。

    //使用vue-cli來安裝electron-vue的模板
    vue init simulatedgreg/electron-vue demo
    

    註:demo 是項目名稱

  3. 安裝依賴

    npm install
    
  4. 啟動項目(開發環境)

    npm run dev
    
  5. 完成1~3步驟,一個基於 vue 的 electron 項目就初始化完成了。

    啟動項目後效果圖如下:

問題解決

初始化報錯

當運行 npm init simulatedgreg/electron-vue demo 命令初始化項目時報錯,大致意思說找不到 electron-vue 或者安裝 create-electron-vue 等原因導致失敗,可以選擇重新運行命令多試幾次,或者先下載electron-vue源碼,然後生成自己的項目模板。下麵說後者的步驟。

  1. electron-vue 下載

  2. cmd 切換到該項目根目錄

  3. 初始化一個自己的項目。初始化完之後可以再命令對應的“目錄路徑”看到你的項目

    vue init 項目路徑 項目名
    
  4. 完成

啟動項目報錯

若第一次啟動項目報錯如下:

大概意思是 提示 src/index.ejs 中沒有定義 process 。

原因分析:大概是 html-webpack-plugin 插件處理該ejs文件時,沒有讀到該插件對應有 process 屬性,應該是去配置文件 "./electron-vue/webpack.render.config.js" 文件中讀取 HtmlWebpackPlugin 插件的 process 屬性,而 "./electron-vue/webpack.render.config.js" 並未定義該屬性,固報此錯。

index.ejs 源碼:

配置文件中插件配置代碼:

解決方法一(推薦):

把index.ejs文件中的 <% if (!process.browser) { %> 改成

<% if (!htmlWebpackPlugin.options.process.browser) { %>

改完後代碼:

index.ejs:

./electron-vue/webpack.render.config.js:

解決方法二:直接刪除下圖中紅框框住部分,沒有什麼影響:

解決方法三:將node 12.x版本還原到10.16的穩定版即可。

註釋:技術推薦Electron 應用技術體系推薦引用他人的electron-vue項目講解的視頻截圖,找不到鏈接了就不寫上了。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.div+css佈局 <div>特征 ① 可以定義文檔中的分區或節(division/section) ② 可以把文檔分割為獨立的、不同的部分,可以用作嚴格的組織工具 ③ 是一個塊級元素,它的內容會自動開始一個新行 ④ 一般通過 id 或 class 標記與CSS配合使用 常用到的CSS屬性: w ...
  • 前言 大家好啊,我是wangly19,一名前端摸魚小能手。最近忙著開源項目的東西,還有公司項目的迭代問題,導致更新文章的頻率有點低了。也來聊聊我在幹嘛吧。 第一個事情就是比較我的閹割版UI Design,要開始Vue3.0的開發工作,所以近期都在看Vue3.0的東西。 其次就是和UI配套的方法庫,也 ...
  • 以上立方體是完全參考 https://blog.csdn.net/liuyingshudian/article/details/105249962 完成。 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>選裝動畫</title> ...
  • 初識CSS 1.0概念以及好處 2.0CSS與HTML結合 (1)內聯樣式 ( 2 ) 內部樣式 ( 3 ) 外部樣式 與CSS更近一步 1.0CSS的使用語法格式 2.0 選擇器 (1) 基礎選擇器 (2) 擴展選擇器 美化頁面的CSS精華 1.0 屬性 下麵是本人做的一個註冊頁面 附上代碼 <! ...
  • 1.CSS用於HTML文檔中元素樣式的定義,實現了將內容與表現分離,提高了代碼的可重用性和可維護性,文件尾碼是“.css” 2.HTML=結構層,CSS=表示層,JavaScript=行為層 3.CSS樣式表的引入方式: ① 內聯方式(行內樣式),直接把CSS代碼用style屬性添加到開始標簽中, ...
  • 打開Javaweb的方式 B/S架構詳解 HTML 1.0 HTML的介紹和快速入門 HTML標簽的詳解 1.0 文件標簽 2.0 文本標簽 3.0 列表標簽 4.0 鏈接標簽 5.0 div/span、語義化標簽 6.0 表格標簽 7.0 表單標簽 (1) 表單項標簽 input 還有一些標簽 ( ...
  • 故事起因: 最近我有個剛畢業的學生問我說:我感覺現在前端行業已經飽和了,也不是說飽和了,是初級的前端根本就沒有公司要,哪怕你不要工資也沒公司要你,前端剛學出來,沒有任何的項目經驗和工作經驗,根本就不會有公司要你啊,這是最大的一個問題,而且現在也沒有任何公司找初級前端,實習前端,都是要求有工作經驗的。 ...
  • 最近在重新學習JavaScript,手寫了一個tabs標簽頁。 話不多說,直接開始。 首先,是前端頁面。 圖1 tabs 先來把tabs分解一下:圖2 tabs分解 首先,一個大的框div,上面紅色的框是導航欄nav,導航欄里是一個無序列表ul,裡面三個li標簽(黃色的框),li標簽里兩個綠色標簽是 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...