vue3 + vite 项目兼容性问题

// vite.config.ts
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'

// https://vitejs.dev/config/
export default defineConfig({
  plugins: [vue()],
  build: {
    target: "es2015"
  }
})

通过指定打包后的目标版本就行了,vite会将新的语法通过esbuild进行转换,此时我们在支持esm的浏览器上访问时正常的。(注意只有打包后的代码才会有效)
我们看下打包后的index.html文件。
在这里插入图片描述
可以看到script标签上使用了type="module"属性,显然即便我们的脚本里面已经兼容到了es2015,但是如果浏览器稍微低一点的版本的,它是支持es2015但是它不支持ESM模块(import/export)啊。

如何兼容不支持esm的浏览器!

官方提供了一个插件:legacy

官方对它的定义是:为打包后的文件提供传统浏览器兼容性支持

其实就是对不支持esm的浏览器的支持,同时还有语法降级处理。

npm i @vitejs/plugin-legacy@4.1.1 terser -D

需要注意的是vite4的legacy插件最高目前是4.1.1,再高的版本只支持vite5了,使用起来会报错。

legacy插件需要依赖terser对代码进行压缩。

使用起来也很简单,我们直接引入插件并启用即可:

// vite.config.js
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import legacy from "@vitejs/plugin-legacy";

// https://vitejs.dev/config/
export default defineConfig({
  plugins: [
    vue(),
    legacy()
  ],
  build: {
    target: "es2015"
  }
})

官方定义,在没有明确指定插件配置参数targets时,他会去读取项目中的.browserslistrc文件,我们知道这个文件是一个用于配置支持的浏览器范围的文件,通常会被Babel、Autoprefixer等插件使用。
在这里插入图片描述
打包之后,index.html 可以看到script发生了变化,除了type="module"还有一个nomodule脚本,nomodule这个属性表示在支持esm的浏览器不运行里面的代码,而不支持esm的浏览器又无法识别type=“module”,反而会去运行nomodule的script,从而实现了降级区分。

这个方式的好处在较新的浏览器中可以使用新的特性,旧的浏览器使用legacy降级脚本,从而避免了以前打包时一刀切的兼容方式,所有的代码全部降级处理,使得一些新设备没法体现出新语法的性能。

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Vue3 Vite项目中配置兼容IE浏览器,可以按照以下步骤进行操作: 1. 为了处理兼容性问题,可以在项目中引入`amfe-flexible`库,该库可以根据设备的屏幕宽度动态设置rem单位的大小。你可以通过在项目中的入口文件中引入`amfe-flexible`来实现这一功能。 2. 另外,你可以使用`@vitejs/plugin-legacy`插件来处理安卓低版本浏览器的兼容性问题。通过在Vite配置文件(`vite.config.ts`)中引入`legacyPlugin`,并将其作为插件使用,可以将ES6+代码转换为向后兼容的代码。 3. 如果你使用的是Vue和iView框架,可以参考一些关于Vue、iView、Webpack和IE浏览器兼容性处理的示例代码,这些示例代码可以帮助你更好地理解和解决兼容性问题。 4. 最后,你可以在开发环境和生产环境的配置文件中,根据需要设置VITE_BASE_PATH变量,以便在不同环境下正确配置静态资源的路径。例如,在`env.development`和`env.production`文件中,可以通过设置`VITE_BASE_PATH=/xxxxx/`来指定基本路径。 总结,要在Vue3 Vite项目中配置兼容IE浏览器,你可以引入`amfe-flexible`库来处理移动设备的兼容性,使用`@vitejs/plugin-legacy`插件来处理安卓低版本浏览器的兼容性,参考示例代码来处理Vue、iView、Webpack和IE浏览器的兼容性,并在配置文件中设置VITE_BASE_PATH变量来配置静态资源的路径。<span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span>

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值