vue2将webpack改为vite

1、修改环境变量:之前vue-cli使用的是VUE_APP开头的环境变量,vite使用的是VITE_开头的环境变量,所以需要修改环境变量。

2、修改环境变量引用:vue-cli使用的是process.env而vite使用的是import.meta.env。

3、index.html文件改动:

1、vite默认会从根目录找index.html文件,所以确保index.html在根目录下。

2、如果有使用HtmlWebpackPlugin插件,在vite中需要使用vite-plugin-html插件。

4、修改page.json文件:

1、运行命令"dev": "vite", 打包命令"build": "vite build"

2、删除core.js包、删除 "@vue/cli-*"相关包、删除sass-loader包、删除babel-*相关包

3、安装 "@vitejs/plugin-vue": "^1.6.1"、"vite": "^2.9.18"、"vite-plugin-vue2": "^1.9.0",

5、删除魔法注解:/* webpackChunkName: "XXXX" */,vite中魔法注释不生效,也可以不删除

6、新增vite.config.js文件:基础配置:

javascript 复制代码
import { defineConfig } from 'vite'
import { createVuePlugin as vue } from "vite-plugin-vue2" // 重要-vue2需要使用

const path = require("path")
export default defineConfig({
  plugins: [vue()],
  resolve: {
    alias: {
      "@": path.resolve(__dirname, "./src"),
    },
    extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.vue'],
  },
  esbuild: {
    // 此配置是为了在vue中使用jsx
    jsxFactory: "h",
    jsxFragment: "Fragment",
    jsxInject: "import { h } from 'vue';",
  }
})

7、删除babel.config.js

8、jsx使用需要在script标签中添加lang="jsx",如:<script lang="jsx">

9、批量引入文件:webpack中使用require.context()批量引入文件,vite中使用import.meta.glob()批量引入文件。

10、全局scss文件:在vite.config.js中配置scss全局样式,且不能再在vue文件中使用import引入,还没找到怎么在template中使用全局样式的方法,如:

javascript 复制代码
css: {
        preprocessorOptions: {
            scss: {
                javascriptEnabled: true,
                additionalData: `
                    @import '文件路径';
                    @import '文件路径';
                `
            }
        }
}

11、将使用的node_modules里使用的包单独打包出来:

javascript 复制代码
build: {
    "minify":false,
    "rollupOptions":{
      "output":{
        "manualChunks":(id)=>{
          if(id.includes('node_modules')){
            return 'vendor';
          }
        }
      }
    }
  }

参考文档:https://vueschool.io/articles/vuejs-tutorials/how-to-migrate-from-vue-cli-to-vite/

相关推荐
放下华子我只抽RuiKe51 小时前
FastAPI 全栈后端(三):数据库与 ORM
前端·数据库·react.js·oracle·性能优化·前端框架·fastapi
梵得儿SHI1 小时前
Vue 项目实战与性能优化全攻略:从代码、渲染到首屏,一站式解决卡顿慢加载
前端·vue.js·性能优化·vite·前端面试·前端优化·首屏优化
ShyanZh1 小时前
【skill】HTML PPT Skill:用 Claude Code 一句话生成专业演示文稿
前端·ai·html·powerpoint·skill
AI视觉网奇2 小时前
three教学 3d资产拼接源代码
前端·css·css3
程序猿阿伟2 小时前
《Chrome标签组搭建多任务高效浏览指南》
前端·chrome
2601_958352903 小时前
双麦 DSP 音频模块实战:一文梳理 A-68 在全行业场景的声学解决方案与落地要点
前端·嵌入式硬件·音视频·语音识别·降噪消回音·音频处理模块
智码看视界3 小时前
老梁聊全栈:JavaScript 原型链深入探索对象继承的奥秘
前端·javascript·ecmascript
布朗克1683 小时前
39 Spring Boot Web实战
前端·spring boot·后端·实战
纽格立科技3 小时前
DRM 发射端链路图(上)
前端·人工智能·车载系统·信息与通信·传媒
一 乐3 小时前
幼儿园管理系统|基于springboot + vue幼儿园管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·幼儿园管理系统