Vue3 + Vite 项目构建兼容低版本浏览器 
Vite项目如何配置构建项 来支持低版本浏览器兼容性,vite官方提供@vitejs/plugin-legac插件来为打包后的文件提供传统浏览器兼容性支持。该项目因为使用 Ant Design for Vue 4+组件库,该版本组件库默认不支持低版本浏览器,但提供兼容样式的配置项。项目中css也需要做向下兼容低版本浏览器,vite提供对应的css配置项,内联了PostCSS配置。
重点在于 Vite 的构建选项、使用 @vitejs/plugin-legacy 插件(需要安装 terser 插件),以及 Ant Design Vue 4 的样式配置。
Vite配置-兼容ts 
在 vite.config.ts 文件中,配置构建选项,并添加 @vitejs/plugin-legacy 插件。
安装 @vitejs/plugin-legacy 及相关依赖 
首先,确保已经安装 @vitejs/plugin-legacy 插件和 terser 插件
npm install @vitejs/plugin-legacy terser --save-dev更新 vite.config.ts 文件 
在 vite.config.ts 文件中,添加对 @vitejs/plugin-legacy 插件的配置
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import legacy from '@vitejs/plugin-legacy'
export default defineConfig({
  plugins: [
    vue(),
    legacy({
      targets: ['defaults', 'Chrome >= 64'],
      additionalLegacyPolyfills: ['regenerator-runtime/runtime'],
      renderLegacyChunks: true,
      polyfills: [
        'es.symbol',
        'es.array.filter',
        'es.promise',
        'es.promise.finally',
        'es.object.assign',
        'es.map',
        'es.set',
        'es.array.for-each',
        'es.object.define-properties',
        'es.object.define-property',
        'es.object.get-own-property-descriptor',
        'es.object.get-own-property-descriptors',
        'es.object.keys',
        'es.object.to-string',
        'web.dom-collections.for-each',
        'esnext.global-this',
        'esnext.string.match-all',
        'es.array.iterator',
        'es.string.includes',
        'es.string.starts-with',
        'es.object.values',
      ],
    })
  ],
  build: {
    minify: 'terser', // 使用 terser 进行压缩
    chunkSizeWarningLimit: 4096,
    terserOptions: {
      compress: {
        drop_console: true, // 可选:移除 console.log 语句
      },
    },
    rollupOptions: {
      output: {
        manualChunks: {
          vue: ['vue', 'vue-router', 'pinia', '@vueuse/core'],
          antd: ['ant-design-vue', '@ant-design/icons-vue'],
        },
      },
    },
    target: ['es2015', 'chrome64'], // 兼容到低版本浏览器,大于等于 chrome64
  },
})2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
构建选项说明 
- legacy 插件配置: - targets: 指定需要支持的浏览器版本。
- additionalLegacyPolyfills: 额外的 polyfill。
- renderLegacyChunks: 是否生成传统版本的 chunk。
- polyfills: 具体的 polyfill 列表。
 
- build 配置: - minify: 使用 terser 进行压缩。
- chunkSizeWarningLimit: 设置 chunk 大小警告阈值。
- terserOptions: terser 压缩选项。
- rollupOptions.output.manualChunks: 自定义 chunk 分割策略。
- target: 指定构建目标,确保生成的代码兼容低版本浏览器。
 
Vite配置-兼容css 
现代浏览器中有一些更简洁的语法正在广泛应用中,如margin-block、flex: end等。这些写法在低版本浏览器无法得到支持,导致页面错乱,最简单的做法就是替换掉这些css,但是无法保证每一个都替换掉,也无法保证后续不会写新css语法,所以需要对项目中所有的css进行兼容。恰巧vite中内联了postcss。我可以通过postcss-preset-env插件将现代 CSS 转换为大多数浏览器可以理解的语法。
安装 
npm i postcss-preset-env --save-dev配置css.postcss 
import poscssPresetEnv from 'postcss-preset-env';
export default defineConfig({
  
  // ... 省略
    
   css: {
      postcss: {
        plugins: [
          poscssPresetEnv(),
        ],
      },
    },
});2
3
4
5
6
7
8
9
10
11
12
13
14
Ant Design Vue 4 的样式兼容 
为了确保 Ant Design Vue 4 的样式在低版本浏览器中正常显示,我们需要进行一些额外的配置。
引入 Ant Design Vue 样式 
在项目的 main.ts 文件中,引入 Ant Design Vue 样式:
import { createApp } from 'vue'
import App from './App.vue'
import Antd from 'ant-design-vue'
import 'ant-design-vue/dist/reset.css'
const app = createApp(App)
app.use(Antd)
app.mount('#app')2
3
4
5
6
7
8
样式兼容 
根据 Ant Design Vue 的兼容性文档,在 Vue 组件中使用 StyleProvider 取消默认的降权操作
<script setup lang="ts">
import zhCN from 'ant-design-vue/es/locale/zh_CN'
import dayjs from 'dayjs'
import 'dayjs/locale/zh-cn'
import { legacyLogicalPropertiesTransformer } from 'ant-design-vue'
dayjs.locale('zh-cn')
const locale = zhCN
const appStore = useAppStore()
</script>
<template>
  <a-config-provider
    :theme="appStore.theme"
    :locale="locale"
  >
    <a-style-provider hash-priority="high" :transformers="[legacyLogicalPropertiesTransformer]">
      <RouterView />
    </a-style-provider>
  </a-config-provider>
</template>2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
