项目从vue2 升级vue3,项目大迁移 ,UI组件库更换

目录

背景描述

开发准备

第一步:升级环境

​编辑​编辑

第二步:划分功能迁移顺序

第三步:详细了解需要迁移的业务页面

第四步:项目的一些配置的准备

第五步:main.ts改成main.js(可忽略)

详细迁移流程介绍

总结


背景描述

之前的版本:vue 2.6.8 + iview 3.3 + element-ui 2.6.1 + echarts 4.2
升级后vue 3 + element-plus + echarts5 

有一个项目的后台管理系统之前一直用的vue2.6.8,大概是5年前开始开发的项目,最近要新写一个项目,但是用到之前的后台管理系统,所以这次leader打算让我将Vue2升级到vue3,因为vue3我最熟练的还是element-ui的组件,所以UI框架打算还是用这个,之前Vue2用的iview的UI虽然好看了一点点,但是这个组件库很多组件有一些弊端,两个组件库混用还有很多不可解决的bug,所以这次干脆弃用。

升级Vue3是一个方面,另一个是要将项目里的功能全部挪过来,虽然admin后台的功能也不多,也就以下几个模块:

1. 人员管理

2.角色权限管理

3.统计汇总

4.操作记录

5.个人设置

6.新增的两个业务页

这几个模块都是admin后台常见的功能,难点是这个后台系统的主要脉络我并不清晰,也就大概了解一些权限方面的控制,详细的功能如果完全升级到vue3的写法,也就要重新写,有一些功能升级起来,肯定要重新测试,并且之前的摒弃的逻辑也要全部了解,所以时间上肯定很紧急,但是我现在也不要求尽善尽美,现将后台的主要功能搭起来,然后一些比如人员管理里面的很多功能,我可以先不做,主要是权限这块还要沿用之前的写法,因为后端不升级,所以接口都复用。


开发准备

先起一个空项目,引用一些必要的框架等,然后就开始迁移旧admin平台的功能。

起项目的过程,很多地方都有教程,我这边就不多讲了,我先梳理我主要的迁移过程。

第一步:升级环境

升级之前看到自己的node 还是14版本,这里先升级node,两种方法,卸载再安装新版本,或者借助NVM来切换node版本,它帮助我们下载安装。我之前写过一篇教程,可以看:NVM使用教程

这次将node升级为20.2.0的版本,所以下载nvm后就很好控制啦:

但是升级完node,还需要对应地升级npm,这里有一个对照表:


我现在的npm 还是6.14.17 所以下一步就是升级npm ,不过nvm直接给我更新啦,很轻松,第一步很顺畅!坏消息是,旧项目,切换了20的版本后就起不来了,不兼容,所以我需要来回切换。


第二步:划分功能迁移顺序

因为是迁移旧项目,并且升级版本,所以前端重新写,但是可以用旧项目的服务,也就是我还可以用旧项目的接口来改造,那么久不用考虑接口,只考虑功能上的迁移顺序了。在这一步,需要先知道,系统内除了业务以外的主要功能,之前梳理的是业务功能,比如各种管理页面,这里是详细的系统迁移的过程:

1.登录、退出功能

2.Axios的封装和API

3.路由跳转和路由表的配置

4.用户信息存储,涉及store

5.权限管理,暂时可以先不管

6.系统的layout开发

7.sidemenu的开发

8.header的开发

9.main区域的开发

10.组件库的引入

11.系统主题样式的引入和迁移

12.开始开发页面

13.图标组件库的引入,SVG的封装
以上等等

第三步:详细了解需要迁移的业务页面

这里是详细的页面:首页、统计汇总、人员管理、项目列表、角色设置、操作记录、个人设置,以及需要新加的两个业务页,其中人员管理和项目列表是共用一个页面,所以,会封装的比较麻烦,后面再开发,而角色管理是控制权限的,所以也后面开发这部分,我先按照超级管理员来写,比较简单写的,肯定是个人设置,首页,所以开发的话,也先开发这部分,之后涉及权限和角色的再详细阐述。

第四步:项目的一些配置的准备

这里是项目的业务开发前的一些准备工作,先把项目配置好,因为用了一个比较简单的模板,所以就先在模板的基础上进行操作。其实要不要模板都一样,只是模板会帮我处理一些琐碎的事情,所以大大节约时间,而且这个模板之前有用过,那就在这个基础上写啦

升级后使用的模板是 vue3-admin-tsicon-default.png?t=N7T8https://github.com/jzfai/vue3-admin-ts

中文官网:vue3-admin-plus | 下一代的前端pc框架 

国内地址:vue3-admin-ts  

在项目的开始开发之前,先将项目的settings设置好,这样才不会格式化冲突,我这里直接粘贴复制的其他项目的。

这里我个人浅浅的见解是,毕竟很多人协同开发项目,编辑器格式化不一样,很容易出现代码覆盖的问题,不方便后期维护和代码历史回溯。

所以我先在项目引入了ESLint 和 Prettier,当然使用哪个看团队要求,我这里是都使用了。

如果接手老项目,要迁移新项目,肯定要将之前项目的规范化要求拿过来,通常是 .eslintrc.js.eslintrc.json.prettierrc.js.prettierrc.json 等文件。我主要改了下面几个:

并且需要配置vscode下的Settings.json文件。

第五步:main.ts改成main.js(可忽略)

并且在一切开始之前,由于工期较短,我自己也比较擅长JS,所以要将一些配置和入口文件的ts改成js格式了,主要的Vue都还是用ts开发,那么这一步,就需要花费一些时间。这部分工作,比较繁琐,根据项目的配置来,每一步都需要查找各个配置和插件之间的关系,很多插件不太了解,所以磕磕绊绊的,但是主要改的是这些:

 箭头指向的都是新加或者修改文件名的ts文件,既然我要用JS来写,而且Ts的一些配置我也不熟悉,那么我干脆就不用TS,但项目还是要TS兼容JS,所以把main,permission,settings这几个文件改成JS写法,然后配置vite.config.js,也就是JS的一些打包配置,jsconfig.json 这是开发配置,其余的配置都不改,这样也顺利启动起来了。


详细迁移流程介绍

系统的基础开发配置大部分弄好了,然后第一步需要做的工作由于引用了模板,所以很多前期工作已经被代替了,这里理了一下详细的内容和流程!

1.系统的第一个功能是登录,那么需要加一个页面,登录页,和登录后的跳转页,登录账号先使用admin账号,将默认跳转到页面先加上,所以现在是加了两个vue页面。

2.需要登录,那么肯定要有路由表,所以这一步,先将原先项目的路由表,升级版本和配置,然后将路由表配置好。

3.登录功能的实现,肯定需要axios的帮助,那么此刻先去将Axios的拦截设置好,然后封装好,将之前的API接口封装成简洁一些的,之前的太杂乱了,API都不放在一块,肯定不好管理。

4.画登录页面,肯定需要组件之类的,之前的样式可以照抄,基本都是几个背景图片和几个输入框,但是组件既然要变成element-plus的,所以要先引入组件库。

5.写登录功能,登录后肯定要存用户信息,而且登录系统后刷新页面会获取用户的信息和权限,所以这一步要使用store,那么此刻也要引入store,到这一步,基本需要导入的库都差不多引用完了。

6.根据划分的功能,来一步步实现需求。

总结

接下来改是从登录页开始开发了,当然有很多琐碎的工作,不过我会划分好模块进行的,可以从专栏里查看。

  • 36
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue.js是一种流行的JavaScript框架,用于构建用户界面。升级Vue 2项目Vue 3可以带来许多新特性和改进。下面是一些升级Vue 2项目Vue 3的步骤和注意事项: 1. 更新Vue CLI:确保你的Vue CLI版本是最新的,可以使用以下命令进行更新: ``` npm install -g @vue/cli ``` 2. 创建新的Vue 3项目:使用Vue CLI创建一个新的Vue 3项目,可以使用以下命令: ``` vue create my-project ``` 3. 迁移代码:将Vue 2项目中的代码逐步迁移Vue 3项目中。在迁移过程中,需要注意以下几点: - Vue 3中的Composition API:Vue 3引入了Composition API,它提供了一种新的组织组件逻辑的方式。可以将Vue 2中的选项API逐渐迁移到Composition API。 - Vue Router和Vuex:如果你在Vue 2项目中使用了Vue Router和Vuex,需要确保它们的版本与Vue 3兼容。可以查阅它们的官方文档来获取升级指南。 - 第三方和插件:检查你在Vue 2项目中使用的第三方和插件是否与Vue 3兼容。有些可能需要更新到最新版本或者寻找替代方案。 4. 测试和调试:在迁移完成后,进行测试和调试以确保项目正常运行。可以使用Vue Devtools等工具来辅助调试。 5. 更新文档和依赖:更新项目的文档和依赖,确保它们与Vue 3的相关版本一致。 6. 逐步发布:如果你的项目是一个大型项目,可以考虑逐步发布。先将一部分功能迁移Vue 3,进行测试和验证,然后再逐步迁移其他部分。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值