当前位置: 首页 > news >正文

vue2项目迁移vue3与gogocode的使用

#背景

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

#升级步骤踩坑

1. 安装 gogocode插件

pnpm install gogocode-cli -g

2. 使用迁移工具将代码从vue2转换到vue3

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

gogocode -s ./src -t gogocode-plugin-vue -o ./src

./src为代码所在文件夹

3. 升级 Element 的引用代码

gogocode -s ./src -t gogocode-plugin-element -o ./src

4. 安装element-plus

pnpm install element-plus

5. 手动修改main.js 里引用

import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'window.$vueApp = Vue.createApp(App) // 放在 import下第一行```
其他文件注册引用
...```window.$vueApp.mount("#app"); //放在最后一行

6. 依赖升级

gogocode -s package.json -t gogocode-plugin-vue -o package.json

7. 参照v-cli文档 迁移webpack相关配置

Migrate from v4 | Vue CLI

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

https://eslint.vuejs.org/user-guide/ 
https://eslint.nodejs.cn/docs/latest/

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

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

import { markRaw } from "vue";
var myChart = markRaw(echarts.init(DOM));

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

import { functionA } from '@/utils'
window.$vueApp.config.globalProperties.functionA = functionA

c. 替换不兼容组件

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

http://www.lryc.cn/news/390769.html

相关文章:

  • 【Python123题库】#数列求和 #百分制成绩转换五分制(循环) #正负交错数列前n项和 #求数列前n项的平方和
  • Edge浏览器选中后,出现AI智能生成 AI专业写作
  • c++习题08-计算星期几
  • 单目相机减速带检测以及测距
  • Xilinx FPGA:vivado实现乒乓缓存
  • 解决 VM 虚拟机网络连接异常导致的 Finalshell 无法连接及 ifconfig 中 ens33 丢失问题
  • 深入Django(三)
  • 观测云赋能「阿里云飞天企业版」,打造全方位监控观测解决方案
  • 51单片机第27步_单片机工作在睡眠模式
  • 互联网应用主流框架整合之SpringCloud微服务治理
  • 超快的 Python 包管理工具「GitHub 热点速览」
  • 网络基础:OSPF 协议
  • 1456.定长子串中元音的最大数目
  • 基于xilinx FPGA的GTX/GTH/GTY位置信息查看方式(如X0Y0在bank几)
  • JAVA小知识30:JAVA多线程篇1,认识多线程与线程安全问题以及解决方案。(万字解析)
  • Python数据分析案例47——笔记本电脑价格影响因素分析
  • 【加密与解密】【09】GPG Client签名流程
  • “2024软博会” 为软件企业提供集展示、交流、合作一站式平台
  • 【Zoom安全解析】深入Zoom的端到端加密机制
  • 7 动态规划
  • .net 快速开发框架开源
  • 《昇思25天学习打卡营第06天|网络构建》
  • 【链表】- 两两交换链表中的节点
  • java设计模式(四)——抽象工厂模式
  • 动物检测yolo格式数据集(水牛 、大象 、犀牛 、斑马四类)
  • 昇思25天学习打卡营第05天 | 数据变换 Transforms
  • Springboot+MySQL 公寓报修管理系统源码
  • jenkins 发布服务到linux服务器
  • Appium+python自动化(三十九)-Appium自动化测试框架综合实践 - 代码实现(超详解)
  • 防止跨站脚本攻击XSS之Antisamy