Skip to content

Latest commit

 

History

History
144 lines (127 loc) · 4.38 KB

README.md

File metadata and controls

144 lines (127 loc) · 4.38 KB

Vite + Vue3 + Element-plus Template

主要整合了 Element-plus 按需引入element-variables.scss 主題參數 引入及打包上的一些設置處理 Deploy : Live Demo by vercel

  • element-plus 按需引入 套件
    • unplugin-element-plus
    • unplugin-vue-components
  • 打包處理 vite.config 套件
    • terser - 打包混淆
    • rollup-plugin-external-globals - 暴露套件參數
    • rollup-plugin-visualizer - 打包解析圖表
    • vite-plugin-compression - gzip壓縮
    • vite-plugin-html - EJS 模板注入 html 功能,可對照 index.thml 上title => <%- title %>

大綱配置

vite.config.js

let cdn = ''
const cdnDomain = 'https://cdn.jsdelivr.net/npm/'

// 須注意版號是否有跟 package.json 一致
const cdnData = [
  '[email protected]/dist/vue.runtime.global.prod.js',
  '[email protected]/lib/index.iife.min.js',
  '[email protected]/dist/pinia.iife.min.js',
  '[email protected]/dist/vue-router.global.min.js',
  '[email protected]/dist/index.full.min.js',
]

cdnData.forEach((str) => (cdn += `<script src="${cdnDomain}/${str}"></script>`))

export default () => {
  return defineConfig({
    css: {
      preprocessorOptions: {
        scss: {
          // 全域引入 scss 變數
          additionalData: `@use "@/assets/styles/element-variables.scss" as *;`
        }
      }
    },
    plugins: [
      // Auto import components
      Components({
        dts: true,
        resolvers: [ElementPlusResolver({
          importStyle: 'sass'
        })],
      }),
      ElementPlus({
        useSource: true,
      }),
      // 打包產生 stats.html 解析圖表
      visualizer({ open: true }),

      // gzip 壓包
      viteCompression({
        verbose: true,
        disable: false,
        threshold: 10240,
        algorithm: 'gzip',
        ext: '.gz'
      }),

      // ※ EJS 模板注入 html 功能
      createHtmlPlugin({
        minify: true,
        inject: {
          data: {
            title: TITLE,
            injectScriptCss: process.env.NODE_ENV === 'production' ? cdn : ''
          }
        }
      })
    ],
    build: {
      minify: 'terser',
      // 生產環境移除 Log
      terserOptions: {
        compress: {
          drop_console: true,
          drop_debugger: true
        }
      },
      rollupOptions: {
        output: {
          // 指定打包 file name
          chunkFileNames: 'static/js/[name]-[hash].js',
          entryFileNames: 'static/js/[name]-[hash].js',
          assetFileNames: 'static/[ext]/[name]-[hash].[ext]'
        },
    

        // ※ 全局引入時,可配置 CDN
        // 套件略過打包項目
        external: ['vue-demi', 'pinia', 'vue', 'vue-router', 'element-plus'],
        plugins: [
          // 暴露參數供外部 CDN 連結調用
          externalGlobals({
            // vue-demi 由於 element-plue、pinia 都要調用此依賴項所以也得優先引入,否則會 Error
            ['vue-demi']: 'VueDemi',
            pinia: 'Pinia',
            vue: 'Vue',
            ['vue-router']: 'VueRouter',
            ['element-plus']: 'ElementPlus',
          })
        ]
      }
    }
  })
}

Build

yarn run v1.22.19
$ vite build
vite v4.5.0 building for production...
✓ 1418 modules transformed.
dist/index.html                             0.41 kB │ gzip:  0.29 kB
dist/static/svg/vue-5532db34.svg            0.50 kB │ gzip:  0.31 kB
dist/static/svg/element-plus-14a55fbf.svg   1.00 kB │ gzip:  0.61 kB
dist/static/css/index-1de2b7af.css          1.26 kB │ gzip:  0.63 kB
dist/static/css/Index-c27252b3.css         62.22 kB │ gzip:  8.12 kB
dist/static/js/default-ff1a6c49.js          0.19 kB │ gzip:  0.17 kB
dist/static/js/Index-9afb15bb.js           49.15 kB │ gzip: 17.94 kB
dist/static/js/index-c3ff1975.js           83.74 kB │ gzip: 32.31 kB
✓ built in 20.98s

✨ [vite-plugin-compression]:algorithm=gzip - compressed file successfully:
dist/C:/Users/User/Desktop/vite_element_plus_template/static/css/Index-c27252b3.css.gz   60.77kb / gzip: 7.93kb
dist/C:/Users/User/Desktop/vite_element_plus_template/static/js/Index-9afb15bb.js.gz     48.16kb / gzip: 17.50kb
dist/C:/Users/User/Desktop/vite_element_plus_template/static/js/index-c3ff1975.js.gz     81.78kb / gzip: 31.52kb

stats.png

License

MIT

Copyright (c) 2023-present, Nick Huang