feat: 添加vite-plugin-pwa插件以支持PWA功能

This commit is contained in:
刘引
2025-10-15 10:48:17 +08:00
parent eb7312fb23
commit 0f59cc6c87
3 changed files with 2916 additions and 11 deletions

View File

@@ -5,7 +5,7 @@ import { dirname, resolve } from 'path'
import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'
import { VitePWA } from 'vite-plugin-pwa'
// ESM 中获取 __dirname 的替代方案
const __filename = fileURLToPath(import.meta.url)
const __dirname = dirname(__filename)
@@ -14,6 +14,41 @@ const __dirname = dirname(__filename)
export default defineConfig({
plugins: [
vue(),
VitePWA({
injectRegister: 'auto',
registerType: 'autoUpdate',
devOptions: {
enabled: true // 是否本地localhost调试pwa
},
workbox: {
// 设置需要缓存的文件类型
globPatterns: ['**/*.{js,css,html,svg,jpg,ico}']
},
manifest: {
name: 'vue模板',
short_name: 'vue模板',
theme_color: '#fff', // 浏览器状态栏主题
start_url: './',
display: 'standalone',
background_color: '#fff',
icons: [
{
src: 'logo.png',
sizes: '144x144',
type: 'image/png',
purpose: 'any'
},
{
src: 'logo.png',
sizes: '512x512',
type: 'image/png',
purpose: 'any'
}
]
}
}),
AutoImport({
resolvers: [ElementPlusResolver()]
}),
@@ -36,7 +71,7 @@ export default defineConfig({
// target: 'http://192.168.39.120:7566',
target: 'http://127.0.0.1:8066',
changeOrigin: true,
rewrite: (p) => p.replace(/^\/api/, ''),
rewrite: p => p.replace(/^\/api/, ''),
bypass: (req, res, options) => {
// @ts-ignore
const proxyURL = options.target + options.rewrite(req.url)