基於 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
  • 1. 說明 /* Performs operations on System.String instances that contain file or directory path information. These operations are performed in a cross-pla ...
  • 視頻地址:【WebApi+Vue3從0到1搭建《許可權管理系統》系列視頻:搭建JWT系統鑒權-嗶哩嗶哩】 https://b23.tv/R6cOcDO qq群:801913255 一、在appsettings.json中設置鑒權屬性 /*jwt鑒權*/ "JwtSetting": { "Issuer" ...
  • 引言 集成測試可在包含應用支持基礎結構(如資料庫、文件系統和網路)的級別上確保應用組件功能正常。 ASP.NET Core 通過將單元測試框架與測試 Web 主機和記憶體中測試伺服器結合使用來支持集成測試。 簡介 集成測試與單元測試相比,能夠在更廣泛的級別上評估應用的組件,確認多個組件一起工作以生成預 ...
  • 在.NET Emit編程中,我們探討了運算操作指令的重要性和應用。這些指令包括各種數學運算、位操作和比較操作,能夠在動態生成的代碼中實現對數據的處理和操作。通過這些指令,開發人員可以靈活地進行算術運算、邏輯運算和比較操作,從而實現各種複雜的演算法和邏輯......本篇之後,將進入第七部分:實戰項目 ...
  • 前言 多表頭表格是一個常見的業務需求,然而WPF中卻沒有預設實現這個功能,得益於WPF強大的控制項模板設計,我們可以通過修改控制項模板的方式自己實現它。 一、需求分析 下圖為一個典型的統計表格,統計1-12月的數據。 此時我們有一個需求,需要將月份按季度劃分,以便能夠直觀地看到季度統計數據,以下為該需求 ...
  • 如何將 ASP.NET Core MVC 項目的視圖分離到另一個項目 在當下這個年代 SPA 已是主流,人們早已忘記了 MVC 以及 Razor 的故事。但是在某些場景下 SSR 還是有意想不到效果。比如某些靜態頁面,比如追求首屏載入速度的時候。最近在項目中回歸傳統效果還是不錯。 有的時候我們希望將 ...
  • System.AggregateException: 發生一個或多個錯誤。 > Microsoft.WebTools.Shared.Exceptions.WebToolsException: 生成失敗。檢查輸出視窗瞭解更多詳細信息。 內部異常堆棧跟蹤的結尾 > (內部異常 #0) Microsoft ...
  • 引言 在上一章節我們實戰了在Asp.Net Core中的項目實戰,這一章節講解一下如何測試Asp.Net Core的中間件。 TestServer 還記得我們在集成測試中提供的TestServer嗎? TestServer 是由 Microsoft.AspNetCore.TestHost 包提供的。 ...
  • 在發現結果為真的WHEN子句時,CASE表達式的真假值判斷會終止,剩餘的WHEN子句會被忽略: CASE WHEN col_1 IN ('a', 'b') THEN '第一' WHEN col_1 IN ('a') THEN '第二' ELSE '其他' END 註意: 統一各分支返回的數據類型. ...
  • 在C#編程世界中,語法的精妙之處往往體現在那些看似微小卻極具影響力的符號與結構之中。其中,“_ =” 這一組合突然出現還真不知道什麼意思。本文將深入剖析“_ =” 的含義、工作原理及其在實際編程中的廣泛應用,揭示其作為C#語法奇兵的重要角色。 一、下劃線 _:神秘的棄元符號 下劃線 _ 在C#中並非 ...