Tauri2-Vite7Admin客户端管理后台|tauri2.9+vue3+element-plus后台系统

news/2025/12/14 12:34:58/文章来源:https://www.cnblogs.com/xiaoyan2017/p/19181509

最新研发tauri2.9+vite7.1+pinia3桌面版高颜值中后台系统TauriVue3Admin

vite7-tauri2-admin最新跨平台技术tauri2.9+vite7.1.12+vue3 setup+pinia3+element-plus+echarts搭建电脑端轻量级管理后台系统模板。提供4种通用布局模板,支持i18n多语言、包含了表格、图表、表单、列表、编辑器、错误处理等业务模块。

360截图20251030220502382

技术栈

  • 开发工具:VScode
  • 跨平台框架:Tauri^2.9
  • 前端技术框架:vite^7.1.12+vue^3.5.22+vue-router^4.6.3
  • 组件库:element-plus^2.11.5
  • 状态管理:pinia^3.0.3
  • 国际化方案:vue-i18n^11.1.12
  • 图表组件:echarts^6.0.0
  • markdown编辑器:md-editor-v3^6.1.0
  • 富文本编辑器:@vueup/vue-quill^1.2.0
  • 模拟数据:mockjs^1.1.0

p2

p3

功能特性

  1. 基于最新跨平台技术栈Tauri2.9、Vite7、Vue3 setup、Pinia3、ElementPlus、Echarts、Vue-I18n
  2. 支持中英文/繁体三种语言
  3. 支持动态路由、面包屑导航、快捷路由标签栏
  4. 内置4种通用布局模板、随意切换风格
  5. 包含常用的图表、表格、表单、列表、编辑器、错误处理等业务场景
  6. tauri2封装多开窗口管理

p4

项目结构目录

tauri2-vue3-admin基于最新跨平台技术 Tauri2.9+Vite7.1 搭建项目框架模板。

360截图20251030220502372

Tauri2.9-ViteAdmin客户端后台系统已经同步到我的原创作品集,欢迎下载使用。

tauri2.9+vue3+element-plus客户端后台系统EXE

p5

项目入口文件

import { createApp } from 'vue'
import './style.scss'
import App from './App.vue'// 引入插件配置
import Plugins from './plugins'// 引入路由/状态管理
import Router from './router'
import Pinia from './pinia'createApp(App)
.use(Router)
.use(Pinia)
.use(Plugins)
.mount('#app')

通用布局模板

image

如上图:项目提供了4种常用布局模板。

image

<script setup>import { appState } from '@/pinia/modules/app'import Toolbar from '@/layouts/components/Toolbar.vue'import Sidebar from '@/layouts/components/sidebar/index.vue'import Menus from '@/layouts/components/menus/index.vue'import Breadcrumb from '@/layouts/components/Breadcrumb.vue'import Tabview from '@/layouts/components/Tabview.vue'import Main from '@/layouts/components/Main.vue'const appstate = appState()
</script><template><div class="vuadmin__layout flexbox flex-col"><Toolbar /><div class="vuadmin__layout-body flex1 flexbox"><!-- 侧边栏 --><div class="vuadmin__layout-sidebar"><Sidebar /></div><!-- 菜单栏 --><div class="vuadmin__layout-menus" :class="{'hidden': appstate.config.collapsed}"><el-scrollbar><Menus :rootRouteEnable="false" /></el-scrollbar></div><!-- 右侧主内容区 --><div class="vuadmin__layout-main flex1 flexbox flex-col"><!-- 面包屑导航 --><Breadcrumb v-if="appstate.config.breadcrumb" /><!-- 标签页 --><Tabview v-if="appstate.config.tabview" /><!-- 内容区 --><Main /></div></div></div>
</template>

360截图20251030221515932

360截图20251030222409100

360截图20251030222619494

360截图20251030224119951

360截图20251030232246233

001360截图20251030233823998

003360截图20251030235230182

005360截图20251031000142107

007360截图20251031000501778

002360截图20251030235111326

010360截图20251031001210670

010360截图20251031001327385

010360截图20251031001352942

011360截图20251031001548691

012360截图20251031002130776

013360截图20251031002208410

016360截图20251031002516399

017360截图20251031002838142

018360截图20251031003049021

019360截图20251031003131463

022360截图20251031003346415

023360截图20251031003449157

023360截图20251031003514335

024360截图20251031003543702

025360截图20251031003713702

image

tauri2+vue3自定义无边框窗口导航栏|系统按钮

image

image

image

image

image

image

<script setup>import { ref, markRaw } from 'vue'import { ElMessageBox } from 'element-plus'import { QuestionFilled, SwitchButton } from '@element-plus/icons-vue'import { getCurrentWindow } from '@tauri-apps/api/window'import { listen } from '@tauri-apps/api/event'import { exit } from '@tauri-apps/plugin-process'import { isTrue } from '@/utils'import { authState } from '@/pinia/modules/auth'const authstate = authState()const props = defineProps({color: String,// 窗口是否可最小化
    minimizable: {type: [Boolean, String], default: true},// 窗口是否可最大化
    maximizable: {type: [Boolean, String], default: true},// 窗口是否可关闭
    closable: {type: [Boolean, String], default: true},// 层级
    zIndex: {type: [Number, String], default: 2024},})const hasMaximized = ref(false)const isResizable = ref(true)const isMaximizable = ref(true)// 用户是否可以手动调整窗口大小
  getCurrentWindow().isResizable().then(res => {isResizable.value = res})// 窗口是否可以最大化
  getCurrentWindow().isMaximizable().then(res => {isMaximizable.value = res})// 初始监听窗口是否最大化
  getCurrentWindow().isMaximized().then(res => {hasMaximized.value = res})// 实时监听窗口是否最大化
  listen('tauri://resize', async() => {hasMaximized.value = await getCurrentWindow().isMaximized()})// 最小化
  const handleWinMin = async() => {await getCurrentWindow().minimize()}// 最大化/还原
  const handleWinToggle = async() => {await getCurrentWindow().toggleMaximize()}// 关闭
  const handleWinClose = async() => {const isMajor = getCurrentWindow().label.indexOf('main') > -1if(isMajor) {ElMessageBox.confirm('是否最小化到系统托盘,不退出程序?', '提示', {type: 'warning',icon: markRaw(QuestionFilled),confirmButtonText: '残忍退出',cancelButtonText: '最小化到托盘',customStyle: {'width': '300px'},draggable: true,roundButton: true,center: true,buttonSize: 'small',distinguishCancelAndClose: true,}).then(async() => {authstate.logout()await exit()}).catch(async(action) => {if(action === 'cancel') {await getCurrentWindow().hide()}})}else {await getCurrentWindow().close()}}
</script><template><div class="ev__winbtns flexbox flex-alignc vu__drag" :style="{'z-index': zIndex}"><div class="ev__winbtns-actions flexbox flex-alignc vu__undrag" :style="{'color': color}"><a v-if="isTrue(minimizable)" class="wbtn min" title="最小化" @click="handleWinMin"><i class="wicon iconfont elec-icon-min"></i></a><a v-if="isTrue(maximizable)" class="wbtn toggle" :title="hasMaximized ? '向下还原' : '最大化'" @click="handleWinToggle"><i class="wicon iconfont" :class="hasMaximized ? 'elec-icon-restore' : 'elec-icon-max'"></i></a><a v-if="isTrue(closable)" class="wbtn close" title="关闭" @click="handleWinClose"><i class="wicon iconfont elec-icon-quit"></i></a></div></div>
</template><style lang="scss" scoped>@use './index.scss';
</style>

vue-i18n多语言配置

image

tauri2-admin支持中英文/繁体三种语言切换,支持自定义配置语言。

image

import { createI18n } from 'vue-i18n'
import { appState } from '@/pinia/modules/app'// 引入语言配置
import enUS from './en-US'
import zhCN from './zh-CN'
import zhTW from './zh-TW'// 默认语言
export const langVal = 'zh-CN'export default async (app) => {const appstate = appState()const lang = appstate.lang || langValappstate.setLang(lang)const i18n = createI18n({legacy: false,locale: lang,messages: {'en': enUS,'zh-CN': zhCN,'zh-TW': zhTW}})app.use(i18n)
}

tauri2-vue3admin自定义动态图表hooks

image

image

image

import { onMounted, onBeforeUnmount, ref } from 'vue'
import * as echarts from 'echarts'
import elementResizeDetectorMaker from 'element-resize-detector'export function useEcharts(el, options) {let chartEllet chartRef = ref(null)let erd = elementResizeDetectorMaker()const resizeHandle = () => {chartEl && chartEl.resize()}onMounted(() => {if(el?.value) {chartEl = echarts.init(el.value)chartEl.setOption(options)chartRef.value = chartEl}erd.listenTo(el.value, resizeHandle)})onBeforeUnmount(() => {chartEl.dispose()erd.removeListener(el.value, resizeHandle)})return chartRef
}

综上就是tauri2+vite7+vue3搭建客户端中后台管理系统的一些知识分享,希望对大家有所帮助!

附上几个最新研发实战项目案例

Tauri2.8+Vue3聊天系统|vite7+tauri2+element-plus客户端仿微信聊天程序

Electron38-Vue3OS客户端OS系统|vite7+electron38+arco桌面os后台管理

electron38-admin桌面端后台|Electron38+Vue3+ElementPlus管理系统

Electron38-Wechat电脑端聊天|vite7+electron38仿微信桌面端聊天系统

vite7-webos网页版os管理|Vue3+Vite7+ArcoDesign搭建pc端os后台系统

最新版uni-app+vue3+uv-ui跨三端仿微信app聊天应用【h5+小程序+app端】

最新版uniapp+vue3+uv-ui跨三端短视频+直播+聊天【H5+小程序+App端】

Flutter3-MacOS桌面OS系统|flutter3.32+window_manager客户端OS模板

最新研发flutter3.27+bitsdojo_window+getx客户端仿微信聊天Exe应用

Uniapp-DeepSeek跨三端AI助手|uniapp+vue3+deepseek-v3流式ai聊天模板

vue3-webseek网页版AI问答|Vite6+DeepSeek+Arco流式ai聊天打字效果

a8a5dc63jw1falkc05snfg206q046gli

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/192926.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

山石防火墙NAT-NAT64

山石防火墙NAT64测试。测试环境如下: 转换前: 3001::1 -> 2011::1 转换后: 21.1.1.1 -> 30.1.1.1Cilent配置 # interface Vlan-interface10 ip address 20.1.1.2 255.255.255.0 # interface LoopBac…

文件多、杂乱,想分类也可以、不想分类也能快速找到文档的解决方案

多数人的常态:我的电脑桌面和云盘里堆满了各种文件夹,命名也比较随意。是的,我们是无法将文件管理得井井有条,至少时间一长,文件一多,就会“乱”。我们要承认和适应自己的这种特点。所以 文档大师 使用的“先收集…

浏览器单击事件绑定空方法为什么能执行

背景 标题就是我之前产生的疑惑。 排查 F12打开开发者工具,选择页面中的那个单击元素。找到事件侦听器 -> click 一般最下面这个就是我们的元素。之所以感到困惑,是因为这个按钮元素绑定的方法是个空函数,但是确…

如何看懂explain工具信息,使用explain工具来分析索引

EXPLAIN 工具能用于获取查询执行计划,即分析 MySQL 如何执行一个 SQL 语句。我们可以通过使用EXPLAIN 去模拟优化器执行 SQL 语句,从而分析 SQL 语句有没有使用索引、是否采用全表扫描方式、判断能否更进一步优化等。…

Memory Profiler说明

Memory Profiler 目录Memory ProfilerMemory Usage On DeviceAllocated MemoryTotal Resident On DeviceAllocated Memory DisriibutionExecutables & MappedAndroid RuntimeNativeManagedGraphics (Estimated)Unt…

软考十

软考十Posted on 2025-10-31 23:24 心默默言 阅读(0) 评论(0) 收藏 举报1. 概述2. 类图3. 用例图4. 顺序图5. 活动图6. 状态图7. 通信图8. 构件图

Amped DVRConv与引擎更新38103:音频转视频容器与解码增强

本次Amped DVRConv和Engine更新38103版本新增了将纯音频文件封装为视频容器的功能,支持6种新的专有格式变体,改进了输入文件位置控制,修复了重复文件队列问题,并新增波兰语支持。Amped DVRConv和引擎更新38103 本次…

(Mutual) correlated agreement

Correlated agreement 形式化定义:Mutual correlated agreement 形式化定义:区别: 前者没有规定折叠后的向量和码字一致的index集合与每个向量一致的index集合相同.作者:神龙小虾出处:https://www.cnblogs.com/yangm…

fastgrind不过如此

fastgrind不过如此博客园的编辑推荐了《一个轻量级C++内存监控及可视化开源库》,下载试了试。 (一)作者忘记#include <array>,编译通不过。 (二)手动插桩 (instrument) 防不了段错误:/home/user/fastgrin…

电动车 NFC 学卡 All In One

电动车 NFC 学卡 All In One NFC 钥匙 / NFC 母卡 / NFC 子卡绿源电动车 ✅ / iPhone Apple 钱包 ✅ / 上海公共交通卡 ✅电动车 NFC 学卡 All In OneNFC 钥匙 / NFC 母卡 / NFC 子卡demos绿源电动车 ✅ / iPhone Ap…

如何设计一个秒杀系统

一:前言 1.在双十一或618期间电商平台会出一些秒杀活动来增加用户活跃带动其余商品销量。2.秒杀系统面临三个问题:数据一致性、服务高性能、服务高可用。3.针对一致性、高性能、高可用的思考1)在高并发的情况下库存…

基于Qlearning强化学习的电梯群控系统高效调度策略matlab仿真

1.算法仿真效果 matlab2022a仿真结果如下(完整代码运行后无水印):2.算法涉及理论知识概要 随着高层建筑的不断增多,电梯成为人们日常生活中不可或缺的垂直交通工具。电梯群控系统(Elevator Group Control System,…

基于Qlearning强化学习的Cart-Pole推车杆平衡控制系统matlab仿真

1.算法仿真效果 matlab2022a仿真结果如下(完整代码运行后无水印):通过不断与环境交互并更新Q值函数,智能体能够逐渐学习到在不同状态下的最优动作,从而实现杆的平衡控制。 仿真操作步骤可参考程序配套的操作视频。…

绿源电动车 NFC 学卡 All In One

绿源电动车 NFC 学卡 All In One NFC 钥匙 / NFC 母卡 / NFC 子卡 Apple 钱包,iPhone 上海公共交通卡 ✅绿源电动车 NFC 学卡 All In OneNFC 钥匙 / NFC 母卡 / NFC 子卡demosApple 钱包,iPhone 上海公共交通卡 ✅…

软考九

软考九Posted on 2025-10-31 22:31 心默默言 阅读(0) 评论(0) 收藏 举报1. 系统设计2. 数据流图

[该退役了]

[该退役了]好了,最近本来说找队友的,结果教练给我找了上次的那个谁 反正是直接导致黑化的决定性因素,也有记录 但是这个人好像是教练的掌中宝啊,不组队还说我伤害了她,然后就宣告不管我了, 简单讲就是这一波是彻…

逆向基础--汇编语言介绍(003)

逆向基础--汇编语言介绍(003)一.前言汇编语言是直接工作在硬件上的一门编程语言,是除了机器语言外的最低层的编程语言了,学习汇编可以帮助我们更加深入的了解cpu,内存等硬件的工作原理。汇编语言和机器语言一般都是一…

文档抽取技术的实现原理及其在法律行业的应用价值分析

想象一位律师,面对堆积如山的案卷:数千页的交易合同、错综复杂的证据材料、浩如烟海的裁判文书。他必须从中精准找出关键条款、锁定矛盾陈述、串联案件事实。这曾是法律工作的常态,耗时耗力且充满疏漏风险。而今,文…

c++写得多不如写得少,同样的逻辑写的多报错逆天

#include<iostream> #include<cstdio> #include<cstring> #include<string> #include<cmath> #include<algorithm> #include<vector> #include<map> #include<uno…