Electron32-ViteOS桌面版os系統|vue3+electron+arco客戶端OS管理模板

来源:https://www.cnblogs.com/xiaoyan2017/p/18396212
-Advertisement-
Play Games

基於electron32+vue3 setup+pinia2桌面端os管理解決方案ElectronVue3OS。 vue3-electron32-os全新原創Electron32+Vite5+Vue3+Pinia2+ArcoDesign+Echarts+Swiper搭建桌面版os管理模板。內置mac ...


基於electron32+vue3 setup+pinia2桌面端os管理解決方案ElectronVue3OS

vue3-electron32-os全新原創Electron32+Vite5+Vue3+Pinia2+ArcoDesign+Echarts+Swiper搭建桌面版os管理模板。內置macos+windows兩種桌面佈局風格、自研可拖拽式柵格佈局模板引擎、支持JSON動態配置桌面菜單/Dock菜單

技術棧

  • 編輯器:vscode
  • 技術框架:vite^5.4.1+vue^3.4.37+vue-router^4.4.3
  • 跨平臺框架:electron^32.0.1
  • 組件庫:@arco-design/web-vue^2.56.0 (位元組前端vue3組件庫)
  • 狀態插件:pinia^2.2.2
  • 拖拽插件:sortablejs^1.15.2
  • 圖表組件:echarts^5.5.1
  • markdown編輯器:md-editor-v3^4.19.2
  • 模擬數據:mockjs^1.1.0
  • 打包構建:electron-builder^24.13.3
  • electron+vite插件:vite-plugin-electron^0.28.7

項目特色

  1. Electron32封裝高性能多開視窗管理
  2. 支持macos/windows兩種桌面模板風格
  3. 支持動態json配置桌面菜單和Dock菜單
  4. 自研柵格化拖拽佈局引擎
  5. 支持自定義桌面主題壁紙、全場景高斯模糊UI質感
  6. 支持主視窗和新開視窗打開路由頁面

項目框架結構

electron-vite-macos使用 vite5.x 整合 electron32 搭建項目框架模板,遵循 Vue3 setup 語法糖編碼風格。

目前Electron32-Vue3-Macos桌面端os系統已經同步到我的原創作品集。

https://gf.bilibili.com/item/detail/1106958011

入口配置main.js

/**
 * 渲染進程配置入口main.js
 * @author andy
 */

import { createApp } from 'vue'
import './style.scss'
import App from './App.vue'

import { launchApp } from '@/windows/actions'

// 引入路由及狀態管理
import Router from './router'
import Pinia from './pinia'

// 引入插件
import Plugins from './plugins'

launchApp().then(config => {
  if(config) {
    // 全局視窗配置
    window.config = config
  }

  // 初始化app實例
  createApp(App)
  .use(Router)
  .use(Pinia)
  .use(Plugins)
  .mount('#app')
})

electron-os桌面佈局結構

內置提供了macos和windows兩種風格桌面模板。

<!-- 桌面模板 -->

<script setup>
  import { appState } from '@/pinia/modules/app'

  // 引入佈局模板
  import MacosLayout from './template/macos.vue'
  import WindowsLayout from './template/windows.vue'

  const appstate = appState()

  const DeskLayout = {
    macos: MacosLayout,
    windows: WindowsLayout
  }
</script>

<template>
  <div class="vu__container" :style="{'--themeSkin': appstate.config.skin}">
    <component :is="DeskLayout[appstate.config.layout]" />
  </div>
</template>

<script setup>
  import Wintool from '@/layouts/components/wintool/index.vue'
  import Desk from '@/layouts/components/mac/desk.vue'
  import Dock from '@/layouts/components/mac/dock.vue'
</script>

<template>
  <div class="vu__layout flexbox flex-col">
    <div class="vu__layout-header">
      <Wintool />
    </div>
    <div class="vu__layout-body flex1 flexbox">
      <Desk />
    </div>
    <div class="vu__layout-footer">
      <Dock />
    </div>
  </div>
</template>

electron-os桌面柵格模板

桌面圖標自定義變數

const deskGridVariable = ref({
  '--icon-radius': '10px', // 圓角
  '--icon-size': '60px', // 圖標尺寸
  '--icon-gap-col': '30px', // 水平間距
  '--icon-gap-row': '30px', // 垂直間距
  '--icon-labelSize': '12px', // 標簽文字大小
  '--icon-labelColor': '#fff', // 標簽顏色
  '--icon-fit': 'contain', // 圖標自適應模式
})

自定義桌面json配置項

/**
  * label 圖標標簽
  * imgico 圖標(本地或網路圖片) 支持Arco Design內置圖標或自定義iconfont字體圖標
  * path 跳轉路由地址
  * link 跳轉外部鏈接
  * hideLabel 是否隱藏圖標標簽
  * background 自定義圖標背景色
  * color 自定義圖標顏色
  * size 柵格佈局(16種) 1x1 1x2 1x3 1x4、2x1 2x2 2x3 2x4、3x1 3x2 3x3 3x4、4x1 4x2 4x3 4x4
  * onClick 點擊圖標回調函數
  * children 二級菜單配置
* isNewin 新視窗打開路由頁面
*/

桌面菜單JSON配置示例

const deskMenu = [
  {
    uid: 'd137f210-507e-7e8e-1950-9deefac27e48',
    list: [
      {imgico: markRaw(Today), size: '2x2'},
      {label: '日曆', imgico: markRaw(Calendar3x3), size: '3x3'},
      {label: 'Electron32', imgico: '/electron.svg', link: 'https://www.electronjs.org/'},
      // ...
    ]
  },
  {
    uid: 'g270f210-207e-6e8e-2650-9deefac27e48',
    list: [
      {label: 'Appstore', imgico: '/static/mac/appstore.png'},
      // ...
    ]
  },
  {
    uid: 't165f210-607e-4e8e-9950-9deefac27e48',
    list: [
      {label: 'Vue.js', imgico: '/vue.svg', link: 'https://vuejs.org/',},
      {label: 'Vite.js官方文檔', imgico: '/vite.svg', link: 'https://vitejs.dev/',},
      // ...
    ]
  },
  {
    uid: 'u327f210-207e-1e8e-9950-9deefac27e48',
    list: [
      {label: 'Electron32', imgico: '/electron.svg', link: 'https://www.electronjs.org/'},
      {label: '首頁', imgico: markRaw(IconHome), path: '/home', color: '#fff', isNewin: true},
      {label: '工作台', imgico: 'elec-icon-dotchart', path: '/home/dashboard', color: '#fff'},
      // ...
      {
        label: '用戶中心',
        children: [
          {label: '主頁', imgico: '/static/svg/ucenter.svg', path: '/setting'},
          {label: '用戶管理', imgico: markRaw(IconUserGroup), path: '/user', color: '#fff'},
          // ...
        ]
      },
      {
        label: '設置',
        children: [
          // ...
        ]
      },
      {
        label: '收藏網址',
        children: [
          {label: 'Electron32', imgico: '/electron.svg', link: 'https://www.electronjs.org/'},
          {label: 'Vite.js', imgico: '/vite.svg',},
          // ...
        ]
      },
      {
        label: '公眾號', imgico: '/static/qrimg.png', color: '#07c160',
        onClick: () => {
          Modal.info({
            // ...
          })
        }
      },
    ]
  }
]

electron32+vue3實現Dock菜單

dock菜單支持如下參數配置

/**
  * label 圖標tooltip提示
  * imgico 圖標(本地或網路圖片) 支持Arco Design內置圖標或自定義iconfont圖標
  * path 跳轉路由頁面
  * link 跳轉外部鏈接
  * color 自定義圖標顏色
  * onClick 點擊圖標回調函數
  * children 二級菜單
  * isNewin 是否新視窗打開路由頁面
  */

OK,以上就是electron32+vue3實戰開發桌面端os系統的一些知識分享,希望對大家有所幫助哈~

Electron打包下載卡頓問題

electron打包進度卡住,下載停滯不前,設置electron淘寶鏡像源依然無效,可以嘗試下麵方法。
直接去 https://registry.npmmirror.com/binary.html 下載相關文件。

下載對應的electron版本文件。

直接將下載的electron打包文件放到C盤下 C:\Users\andy\AppData\Local\electron\Cache

通過手動下載打包文件,electron打包時就跳過下載步驟,很快就能打包成功了。

vite.config.js配置@/無路徑提示解決方法

安裝如下方式配置vscode的@路徑提示

  1. vscode安裝Path Intellisense插件
  2. 點擊左下角齒輪,點擊設置
  3. 點擊右上角這個圖標

配置如下代碼

"path-intellisense.mappings": {
    "@": "${workspaceFolder}/src"
}

保存退出,@/就會有路徑提示了。

最後附上兩個最新Electron+Vite5實例項目

https://www.cnblogs.com/xiaoyan2017/p/18290962

https://www.cnblogs.com/xiaoyan2017/p/18366451

 

本文為博主原創文章,未經博主允許不得轉載,歡迎大家一起交流 QQ(282310962) wx(xy190310)
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 受 LabelImg 啟發的基於 web 的圖像標註工具,基於 Vue 框架 喲,網友們好,年更鴿子終於想起了他的博客園密碼。如標題所述,今天給大家帶來的是一個基於 vue2 的圖像標註工具。至於它誕生的契機呢,應該是我導 pass 掉了我的提議(讓甲方使用 LabelImg 進行數據標註),說是要 ...
  • title: 使用 nuxi init 創建全新 Nuxt 項目 date: 2024/9/6 updated: 2024/9/6 author: cmdragon excerpt: 摘要:本文介紹瞭如何使用nuxi init命令創建全新的Nuxt.js項目,包括安裝所需環境、命令使用方法、指定模板 ...
  • element-ui 的組件庫中沒有圖片下拉選擇組件,基於 el-select 組件做的改動並不能完全滿足需求,因此決定重寫一個。 從頭到尾做下來收穫很多,我決定把實現過程中遇到的問題記錄一下。 效果圖 線上試用地址 設計要點 接下來將上面代碼中的關鍵部分拆分介紹 1. 回顯選中的圖片和 label ...
  • Vue3.5正式版在這兩天發佈了,網上已經有了不少關於Vue3.5版本的解讀文章。但是歐陽發現這些文章對3.5中新增的功能介紹都不是很全,所以導致不少同學有個錯覺,覺得Vue3.5版本不過如此 ...
  • title: 使用 nuxi info 查看 Nuxt 項目詳細信息 date: 2024/9/5 updated: 2024/9/5 author: cmdragon excerpt: 摘要:文章介紹了nuxi info命令的使用方法,這是一個Nuxt.js命令行工具,用於查看當前或指定Nuxt項 ...
  • 第一步:安裝 npm 使用以下命令安裝npm install vue-grid-layout --save yarn 使用以下命令安裝yarn add vue-grid-layout 第二步:配置全局變數 import { createApp } from 'vue' import App from ...
  • 前言 前端導出表格有很多種方案,但是表格樣式一旦複雜了,那麼就得用代碼寫excel的樣式,還是比較麻煩的。每次樣式不一樣,就得重新寫,這時使用表格模板的優勢就體現出來了,想導出不同樣式的表格直接修改表格模板即可。 方案 我找了兩種方案: 1、使用xlsx-template,利用模板語法在xlsx中占 ...
  • 前言 vue3中想要訪問DOM和子組件可以使用ref進行模版引用,但是這個ref有一些讓人迷惑的地方。比如定義的ref變數到底是一個響應式數據還是DOM元素?還有template中ref屬性的值明明是一個字元串,比如ref="inputEl",怎麼就和script中同名的inputEl變數綁到一塊了 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...