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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...