使用Electron開發桌面應用

来源:https://www.cnblogs.com/itqn/archive/2020/07/05/electron_helloworld.html
-Advertisement-
Play Games

Electron是一個可以使用 JavaScript,HTML 和 CSS 構建跨平臺桌面應用程式的開源框架。 本文主要分享一下採用vue + electron開發桌面程式的搭建過程。 1. 環境準備 這裡採用的是vue-cli3.x,可以通過下麵的指令查看當前vue-cli的版本: vue --v ...


Electron是一個可以使用 JavaScript,HTML 和 CSS 構建跨平臺桌面應用程式的開源框架。

本文主要分享一下採用vue + electron開發桌面程式的搭建過程。

1. 環境準備

這裡採用的是vue-cli3.x,可以通過下麵的指令查看當前vue-cli的版本:

vue --version
# 3.9.3 這裡我用的是3.9.3

如果沒有裝vue-cli可以通過下麵的命令安裝:

npm install -g @vue/cli

如果是vue-cli還是2.x可以先卸載2.x然後裝3.x

npm uninstall vue-cli -g
npm install -g @vue/cli

2. 創建項目

這裡採用vue-cli創建vue項目。

vue create electron-helloworld

引入vue-cli-plugin-electron-builder

cd electron-helloworld
vue add electron-builder

這一步需要拉取electron-vX.Y.Z-win32-x64.zip,過程非常漫長。

3. 運行項目

運行electron項目。

npm run electron:serve

Electron

4. node通訊

正常來說vue組件應該只關心頁面層的邏輯即可,所以為瞭解耦,可以在Vue ComponentNode APIElectron API中間插入一個橋接層,然後通過IPC進行通訊,如下圖所示:

IPC

按照關係圖,Vue Commponent通過Service發佈事件,完成與Node APIElectron API的通訊,下麵根據這個關係寫一個讀取文件內容的示例。

創建Service,發佈事件並監聽

/bridge/service/Service.js

import { ipcRenderer } from 'electron'
class Service {
  readTxt(params, callback) {
    ipcRenderer.once('readTxt', (e, ret) => callback(ret))
    // 將params參數傳給Server
    ipcRenderer.send('readTxt', params)
  }
}
export default new Service()

創建Server,監聽事件並讀取文件內容返回

/bridge/server/Server.js

import { ipcMain } from "electron";
import fs from 'fs'
export default class Server {
  constructor(app, win) {
    this.app = app
    this.win = win
  }
  initEventHandler() {
    ipcMain.on('readTxt', (e, params) => {
      // 這裡將參數轉化為json,然後讀取G:\\0.txt的內容一起返回
      const pms = JSON.stringify(params)
      const ret = fs.readFileSync('G:\\0.txt')
      e.sender.send('readTxt', pms + '::::' + ret)
    })
  }
}

啟動Server

在創建完Server之後,需要在應用程式啟動的時候啟動並讓其監聽對應的事件。

這裡可以創建一個ApplicationContext,來啟動Server。

/bridge/ApplicationContext.js

import Server from './server/Server'
export default class ApplicationContext {
  constructor(app, window) {
    this.app = app
    this.window = window
  }
  init() {
    new Server(this.app, this.window).initEventHandler()
  }
}

然後在background.js中實例化ApplicationContext,並調用init方法。

  win.on('closed', () => {
    win = null
  })
  // Windows創建完成後初始化context
  new ApplicationContext(app, win).init()

Vue組件調用Service

完成上面三步之後,只需要在vue組件中調用Service即可,這一步跟普通開發vue程式是一樣的。

<div>{{txt}}</div>
<button @click="readTxt">讀取文件信息</button>
<script>
import service from '@/bridge/service/Service'
export default {
  name: 'HelloWorld',
  props: {
    msg: String
  },
  data() {
    return {
      txt: ''
    }
  },
  methods: {
    readTxt() {
      // 這裡傳入兩個參數,並將返回結果賦值給txt,在div中顯示出來
      service.readTxt({
        p1: '參數1',
        p2: '參數2'
      }, resp => {
        this.txt = resp
      })
    }
  }
}
</script>

至此,一個electron helloworld示例就完成了。

5. node API undefind

在上面的過程中可能會遇到node API undefined的情況,這是因為electron禁用了node集成,在background.js中創建window的時候指定了配置:

webPreferences: {
      // Use pluginOptions.nodeIntegration, leave this alone
      // See nklayman.github.io/vue-cli-plugin-electron builder/guide/security.html#node-integration for more info
      nodeIntegration: process.env.ELECTRON_NODE_INTEGRATION
     // nodeIntegration: true
}

這裡可以通過配置electronBuilder插件解決。

在項目目錄根目錄下麵創建vue.config.js,內容如下:

// see https://cli.vuejs.org/config
module.exports = {
  productionSourceMap: false,
  pluginOptions: {
    electronBuilder: {
      nodeIntegration: true,
    },
    configureWebpack: {
      resolve: {
        symlinks: true
      }
    }
  }
}

項目源碼可關註公眾號 “HiIT青年” 發送 “electron-helloworld” 獲取。

HiIT青年
關註公眾號,閱讀更多文章 (如打包成exe,版本自動升級)。


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

-Advertisement-
Play Games
更多相關文章
  • MySQL 樹形索引結構 B樹 B+樹 如何評估適合索引的數據結構 索引的本質是一種數據結構 記憶體只是臨時存儲,容量有限且容易丟失數據。因此我們需要將數據放在硬碟上。 在硬碟上進行查詢時也就產生了硬碟的I/O操作,而硬碟的I/O存取消耗的時間要比讀取記憶體大很多。因此數據查詢的時間主要決定於I/O操作 ...
  • 一、數組中其餘的常用方法 包括map,filter,every,some方法,我們分別進行舉例 //map定義一個函數用來遍歷原來老的數組 var arr = [10,20,5,1000,50]; var newArr = arr.map(function(value, index, array){ ...
  • Pointer Events API 是Hmtl5的事件規範之一,它主要目的是用來將滑鼠(Mouse)、觸摸(touch)和觸控筆(pen)三種事件整合為統一的API。 Pointer Event Pointer指可以在屏幕上反饋一個指定坐標的輸入設備。Pointer Event事件和Touch E ...
  • 1.塊級元素水平垂直居中 方法1 1 <!--(該方法相容ie8以上瀏覽器)--> 2 position: absolute/fixed; 3 left:0; 4 top:0; 5 right: 0; 6 bottom: 0; 7 margin:auto; 方法2: 1 <!--前提條件:必需知道該 ...
  • 在“JavaScript圖形實例:迭代函數系統生成圖形”一文中,我們介紹了採用迭代函數系統(Iterated Function System,IFS)創建分形圖案的一些實例。在該文中,仿射變換函數W的一般形式為 X1=a*X0 + b*Y0 + e Y1=c*X0 + d*Y0 + f 給定不同的I ...
  • First. 什麼是 algolia search? 根據algolia官方網站自我闡述:Algolia是一個托管搜索引擎,提供全文,數字和多面搜索,能夠從第一次擊鍵中提供實時結果。 Algolia強大的API可讓您快速無縫地在網站和移動應用程式中實施搜索。我們的搜索API每月為成千上萬的公司提供數 ...
  • 在“JavaScript圖形實例:SierPinski三角形” 和“JavaScript圖形實例:Levy曲線及其變形”等文章中我們介紹了通過遞歸生成分形圖形的方法。我們可以將繪製的分形圖形每隔一定的時間間隔後,增加遞歸深度重新繪製一次,這樣就可以得到分形圖形的動態生成效果。 1.SierPinsk ...
  • Nuxt 是 Vue 項目伺服器端渲染(SSR)解決方案。而在使用時,就會遇到前後端分離情況下的功能變數名稱或埠不一致導致的跨域問題。本文將介紹如何通過設置代理解決 Nuxt 與 axios 集成的跨域問題。 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:在C#中,++i和i++都是自增運算符,其中++i先增加值再返回,而i++先返回值再增加。應用場景根據需求選擇,首碼適合先增後用,尾碼適合先用後增。詳細示例提供清晰的代碼演示這兩者的操作時機和實際應用。 在C#中,++i 和 i++ 都是自增運算符,但它們在操作上有細微的差異,主要體現在操作的 ...
  • 上次發佈了:Taurus.MVC 性能壓力測試(ap 壓測 和 linux 下wrk 壓測):.NET Core 版本,今天計劃準備壓測一下 .NET 版本,來測試並記錄一下 Taurus.MVC 框架在 .NET 版本的性能,以便後續持續優化改進。 為了方便對比,本文章的電腦環境和測試思路,儘量和... ...
  • .NET WebAPI作為一種構建RESTful服務的強大工具,為開發者提供了便捷的方式來定義、處理HTTP請求並返迴響應。在設計API介面時,正確地接收和解析客戶端發送的數據至關重要。.NET WebAPI提供了一系列特性,如[FromRoute]、[FromQuery]和[FromBody],用 ...
  • 原因:我之所以想做這個項目,是因為在之前查找關於C#/WPF相關資料時,我發現講解圖像濾鏡的資源非常稀缺。此外,我註意到許多現有的開源庫主要基於CPU進行圖像渲染。這種方式在處理大量圖像時,會導致CPU的渲染負擔過重。因此,我將在下文中介紹如何通過GPU渲染來有效實現圖像的各種濾鏡效果。 生成的效果 ...
  • 引言 上一章我們介紹了在xUnit單元測試中用xUnit.DependencyInject來使用依賴註入,上一章我們的Sample.Repository倉儲層有一個批量註入的介面沒有做單元測試,今天用這個示例來演示一下如何用Bogus創建模擬數據 ,和 EFCore 的種子數據生成 Bogus 的優 ...
  • 一、前言 在自己的項目中,涉及到實時心率曲線的繪製,項目上的曲線繪製,一般很難找到能直接用的第三方庫,而且有些還是定製化的功能,所以還是自己繪製比較方便。很多人一聽到自己畫就害怕,感覺很難,今天就分享一個完整的實時心率數據繪製心率曲線圖的例子;之前的博客也分享給DrawingVisual繪製曲線的方 ...
  • 如果你在自定義的 Main 方法中直接使用 App 類並啟動應用程式,但發現 App.xaml 中定義的資源沒有被正確載入,那麼問題可能在於如何正確配置 App.xaml 與你的 App 類的交互。 確保 App.xaml 文件中的 x:Class 屬性正確指向你的 App 類。這樣,當你創建 Ap ...
  • 一:背景 1. 講故事 上個月有個朋友在微信上找到我,說他們的軟體在客戶那邊隔幾天就要崩潰一次,一直都沒有找到原因,讓我幫忙看下怎麼回事,確實工控類的軟體環境複雜難搞,朋友手上有一個崩潰的dump,剛好丟給我來分析一下。 二:WinDbg分析 1. 程式為什麼會崩潰 windbg 有一個厲害之處在於 ...
  • 前言 .NET生態中有許多依賴註入容器。在大多數情況下,微軟提供的內置容器在易用性和性能方面都非常優秀。外加ASP.NET Core預設使用內置容器,使用很方便。 但是筆者在使用中一直有一個頭疼的問題:服務工廠無法提供請求的服務類型相關的信息。這在一般情況下並沒有影響,但是內置容器支持註冊開放泛型服 ...
  • 一、前言 在項目開發過程中,DataGrid是經常使用到的一個數據展示控制項,而通常表格的最後一列是作為操作列存在,比如會有編輯、刪除等功能按鈕。但WPF的原始DataGrid中,預設只支持固定左側列,這跟大家習慣性操作列放最後不符,今天就來介紹一種簡單的方式實現固定右側列。(這裡的實現方式參考的大佬 ...