前言

项目全线使用vue3的时候,自然使用的是配套更加契合的vite打包工具,于是自然而然会用到很多新的语法,比如这两年开始普及的可选链语法,这个语法都已经纳入声呐的代码规范中了,但是vite自身打包的时候,并不会做过多的兼容处理。

默认情况vite的兼容目标是支持原生ES模块原生ESM动态导入import.meta的浏览器,官方预设的兼容目标如下:

  1. es2020
  2. edge 88
  3. firefox 78
  4. chrome 87
  5. safari 14

而我们的可选链正是es2020版本才有的,所以vite在打包后不会做任何兼容处理,这就导致了一些浏览器版本低一点的设备,打开网站就会出现白屏的情况。

显然这么新的版本在大部分的目标用户中,也是很超前的,所以做一些适当的兼容处理还是有必要的。

教程

此处内容已隐藏回复后方可阅读。

分类: vue 项目实战 标签: vue3vite兼容低版本白屏legacyNuxt3

评论

全部评论 90

  1. 1
    1
    Google Chrome Windows 10
    习学习学习学习学习学习学习
  2. QuXin
    QuXin
    Google Chrome Windows 10
    感谢大佬分享
  3. 12315
    12315
    Google Chrome Windows 10
    1132132说说啥
  4. 123
    123
    Google Chrome Windows 10
    可以说下 nuxt 版本吗 我nuxt3.5.0 @vitejs/plugin-legacy 4.1.1 npm run generate后发现只有依旧只有type="module"文件
    1. 木灵鱼儿
      木灵鱼儿
      FireFox Windows 10
      @123可能确实有问题了,nuxt的这套方式好像只能处理css的兼容,js的不行
    2. 木灵鱼儿
      木灵鱼儿
      FireFox Windows 10
      @123

      我都是最新的了。
      "@vitejs/plugin-legacy": "^5.4.1",
      "nuxt": "^3.12.4"

  5. 123
    123
    Google Chrome Windows 10
    111阿斯蒂芬
  6. 666
    666
    Google Chrome Windows 10
    ????a啊???
  7. aa
    aa
    Google Chrome MacOS
    XXXAF发
  8. Jelly
    Jelly
    Google Chrome Windows 10
    666666奈斯
  9. 111
    111
    Google Chrome Windows 10
    1111正好需要
  10. 3237
    3237
    Google Chrome Windows 10
    666膜拜

目录