vue2项目迁移vue3与gogocode的使用

#背景

公司有个项目使用vue2+js+webpack框架开发的,由于该项目内部需要安扫,导致很多框架出现了漏洞需要升级,其中主要需要从vue2升vue3,但是重新搭框架推翻重做成本太高,于是找到了gogocode。

#升级步骤踩坑

  1. 安装 gogocode插件
bash 复制代码
pnpm install gogocode-cli -g
  1. 使用迁移工具将代码从vue2转换到vue3

gogocode/packages/gogocode-plugin-vue at main · thx/gogocode · GitHub

bash 复制代码
gogocode -s ./src -t gogocode-plugin-vue -o ./src

./src为代码所在文件夹

  1. 升级 Element 的引用代码
bash 复制代码
gogocode -s ./src -t gogocode-plugin-element -o ./src
  1. 安装element-plus
bash 复制代码
pnpm install element-plus
  1. 手动修改main.js 里引用
javascript 复制代码
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'

window.$vueApp = Vue.createApp(App) // 放在 import下第一行

```
其他文件注册引用
...

```

window.$vueApp.mount("#app"); //放在最后一行
  1. 依赖升级
bash 复制代码
gogocode -s package.json -t gogocode-plugin-vue -o package.json
  1. 参照v-cli文档 迁移webpack相关配置

Migrate from v4 | Vue CLI

  1. 升级eslint相关依赖版本及配置至支持vue3

https://eslint.vuejs.org/user-guide/

https://eslint.nodejs.cn/docs/latest/

  1. 修复代码里的其他报错

a. 如在项目中引入了echarts依赖,在初始化时应使用markRaw

javascript 复制代码
import { markRaw } from "vue";
var myChart = markRaw(echarts.init(DOM));

b. Util中的公用方法用export导出在main中引用

javascript 复制代码
import { functionA } from '@/utils'
window.$vueApp.config.globalProperties.functionA = functionA

c. 替换不兼容组件

d. 根据报错提示修复代码

相关推荐
大转转FE1 分钟前
转转前端周刊第191期: 淘宝闪购 AI Agent 的秒级响应记忆系统
前端·人工智能
怪我冷i3 分钟前
在win11进行Rust Web 开发,采用Salvo框架
开发语言·前端·rust
candyTong4 分钟前
Claude Code 是怎么跑起来的:从 Agent Loop 理解代理循环实现
前端·后端·ai编程
倾颜7 分钟前
我是怎么把 Multi-Tool Runtime 升级成第一层 Skill Runtime 的
前端·llm·next.js
qq_406176148 分钟前
React 状态管理完全指南:从入门到选型
前端·javascript·react.js
thatway19899 小时前
闲聊-关于AI终结者的警醒
前端
努力的小郑9 小时前
突发!Claude Code 51万行源码全网裸奔:一场史诗级“开源”事故,国内大厂笑麻了
前端·后端·ai编程
七度黑光9 小时前
用 openclaw 给故障复盘打分:质量审核自动化实践
运维·服务器·前端·数据库·自动化
HashTang9 小时前
Claude Code 源码中 REPL.tsx 深度解析:一个 5005 行 React 组件的架构启示
前端·后端·ai编程
wendycwb10 小时前
前端城市地址根据最后一级倒推,获取各层级id的方法
前端·vue.js·typescript