最近想用Electron来进行跨平台的桌面应用开发。同时想用vuetify作为组件,于是想搭建一个这样的开发环境。其中踩了不少坑,总是会出现各种的编译错误和问题,依赖的各种问题,搞了好久最终环境终于弄好可正常开发了。这里分享下快速搭建的流程和方法。
如果你用官网的Build cross-platform desktop apps with JavaScript, HTML, and CSS | ElectronBuild cross-platform desktop apps with JavaScript, HTML, and CSS
https://www.electronjs.org/上面的方法,搭建出来啥也没有,会比较麻烦。
这个项目很好的解决了Electron+vite的快速搭建。详见网站electron-vite | Next Generation Electron Build ToolingNext generation Electron build tooling based on Vite.
https://electron-vite.org/
命令很简单,如果是使用yarn的话,输入命令
yarn create @quick-start/electron
如果是npm则输入命令
npm create @quick-start/electron@latest
然后,就是根据提示,一步一步的就创建了对应的项目了,非常的方便。
创建好了之后,就准备开始添加vuetify了。
然后用yarn安装
- yarn add -D vuetify vite-plugin-vuetify
- yarn add @mdi/font
或者是用npm来安装
- npm i -D vuetify vite-plugin-vuetify
- npm i @mdi/font
安装好了之后,需要做以下的修改,首先根目录下的electron.vite.config.mjs文件,import一下vuetify,然后在plugins中间需要添加vuetify插件,整个文件修改完成后如下:
- import { resolve } from 'path'
- import { defineConfig, externalizeDepsPlugin } from 'electron-vite'
- import vue from '@vitejs/plugin-vue'
- import vuetify, { transformAssetUrls } from 'vite-plugin-vuetify'
- export default defineConfig({
- main: {
- plugins: [externalizeDepsPlugin()]
- },
- preload: {
- plugins: [externalizeDepsPlugin()]
- },
- renderer: {
- resolve: {
- alias: {
- '@renderer': resolve('src/renderer/src')
- }
- },
- plugins: [vue(),vuetify({ autoImport: true })]
- }
- })
然后,在src文件夹中创建plugins文件夹,并添加vuetify.js文件,如果用的是ts也类似。
/src/plugins/vuetify.js文件内容如下:
- import '@mdi/font/css/materialdesignicons.css'
- import 'vuetify/styles'
-
- const vuetify = createVuetify({
- ssr: true,
- })
最后,找到main.js文件,添加vuetify相关的内容,最终修改如下:
- import './assets/main.css'
-
- import { createApp } from 'vue'
-
- // Vuetify
- import 'vuetify/styles'
- import { createVuetify } from 'vuetify'
- import * as components from 'vuetify/components'
- import * as directives from 'vuetify/directives'
-
- import App from './App.vue'
-
- const vuetify = createVuetify({
- components,
- directives,
- })
-
- createApp(App).use(vuetify).mount('#app')
OK,接下来就可以正常的使用vuetify的组件了。