2025年vue2升级3(vue2升级到vue3算重构吗)

vue2升级3(vue2升级到vue3算重构吗)svg xmlns http www w3 org 2000 svg style display none svg

大家好,我是讯享网,很高兴认识大家。



 <svg xmlns="http://www.w3.org/2000/svg" style="display: none;"> <path stroke-linecap="round" d="M5,0 0,2.5 5,5z" id="raphael-marker-block" style="-webkit-tap-highlight-color: rgba(0, 0, 0, 0);"></path> </svg> 

讯享网

前段时间,公司准备在现有的 Vue2 项目中做一个聊天系统,但考虑开发聊天系统的周期并不短,客户又急需。于是准备对接腾讯的 IM 组件,来实现。

不知道的这里贴个官网: IM TUIKit 官方文档

对于 TUIKit,官方文档上有以下要求:
在这里插入图片描述
讯享网
然而我们公司项目是使用 Vue2 版本的,这显然不符合要求。如果要对接,那么必然要升级项目为Vue3 版本。

首先要明白,Vue2 升级 Vue3 能带来什么?

总结一下下列几点:

1. 增加了代码的可维护性

Vue2 使用的是 options 的API ,代码逻辑比较分散,可读性差,可维护性差。Vue3 使用的是 compositionAPI 逻辑分明,可维护性高,更友好的支持TS。在 template 模板中支持多个根节点,支持jsx语法。

2. 提升了页面渲染性能

Vue3 在更新DOM算法上,做了优化。在 Vue2 中,每次更新diff,都是全量对比,Vue3则只对比带有标记的,这样大大减少了非动态内容的对比消耗。

3. 加强了 MVVM 双向数据绑定的效率

  1. defineProperty只能监听某个属性,不能对全对象监听
  2. 可以省去for in、闭包等内容来提升效率(直接绑定整个对象即可)
  3. 可以监听数组,不用再去单独的对数组做特异性操作 vue3.x 可以检测到数组内部数据的变化

4. 项目可持续发展

Vue 2官方还会再维护两年,但两年后的问题和需求,官方就不承诺修复和提供解答了,Vue 3 则不会。

当然,还有其他的,这里只是列出几个主要的。

  1. 新的响应式系统用了 Proxy,会存在兼容性问题(不支持IE)。
  2. 框架底层进行了大量重构,新增和删除了很多原来的API,代码结构也发生了变化。很多地方需要进行破坏性修改,从而容易导致各种问题的出现。
  3. 项目使用到的第三方插件和 UI框架(Element)也需要替换和更改成 对应Vue3可用版本。

通过工具+手动升级

第一版可以先从基础进行迁移。完成框架整体升级到Vue3(可运行)之后可以进行细化。

第一步: 先把Vue2 框架整体替换成 Vue3,因为目前 Vue3也是兼容了 Options 写法,这样代码结构可以先不用更改,后期可以逐步修改(因为涉及到所有页面和组件)。之后新增的页面和组件按照 Vue3 新增的 compositionAPI 结构来写。

第二步: 把 Vue3 中已经不再支持的 API 和语法进行修改替换。包括 Vue3 已经不再支持过滤器filter,v-model 用法也改变等。

第三步: 把项目使用到的第三方插件和UI框架(Element)替换成Vue3版本,对应用法可能也需要修改。需要通过 package.json 里注册目录,在页面进行检索修改。

对于这一步升级有以下几点比较麻烦:

  1. 项目中依赖的库并不支持vue3
  2. vue2到vue3的一些破坏性更改
  3. 项目中依赖组件库(ElementUI等)的破坏性更改
  4. 对一些新特性的尝试(vite,ts,pinia)等 公司项目迁移造成稳定性破坏(极其重要)

第四步: 确保项目代码语法编译无误后,需要检查代码中的业务是否正确,避免对公司项目迁移造成稳定性破坏(极其重要)。

第五步: 使用 TypeScript 重构 JS 代码,TypeScript 比 JavaScript 多了静态类型检查,也增加了一些新的语法,是给项目锦上添花。但是这一步会比较耗时(因为相当于修改把JS代码都要过一遍),但是项目中可以同时存在JS 和 TS,所以可以逐步替换。

使用自动化工具:
通过使用目前比较好用的开源工具可以完成第一步和第二步的转换,目前使用比较多的就是 :文档

对于工具改造代码,存在很多未知性,项目业务代码中有些比较复杂的(例如表单联动,规则校验等等)可能会对原来的逻辑有影响,需要逐一人工比对和测试。

1. 创建一个新的 vue3 + TS 项目,里面安装完相关基础依赖

整个项目重新搭建,使用了 Vue3 作为技术框架。使用了 Vite 作为打包和构建工具(代替了之前 Vue2 的 Webpack 构建工具),因为 Vite 拥有更好的打包编译性能。
在这里插入图片描述
增加了 TypeScript 依赖,可以作为 TS 代码编写编译,增强了项目可持续维护性(之后可转成全TS)。使用 VueRouter 4.1.1 版本作为项目页面路由控制,此版本为 Vue3 配套版本。使用了 Pinia 代替了 Vuex 作为统一状态管理模块,因为 Pinia 与 Vuex 相比,Pinia 提供了一个更简单的 API,具有更少的规范,提供了 Composition-API 风格的 API,最重要的是,在与 TypeScript 一起使用时具有可靠的类型推断支持。Api请求模块仍然采用了易用、简洁且高效的http库 Axios。使用 Sass 作为 CSS 的预编译语言,增强 CSS 的灵活性。使用升级版 Element Plus 作为界面 UI 框架。

技术栈
Vue3
TypeScript

TypeScript 官网文档:https://www.tslang.cn/

VueRouter

VueRouter 官网及其介绍: https://router.vuejs.org/zh/

Pinia

Pinia 官网及其介绍:https://pinia.web3doc.top/

Axios

Axios 官网及其介绍:http://www.axios-js.com/

Sass

Sass 官网及其介绍:https://www.sass.hk/

Element Plus

Element Plus 官网及其介绍:https://element-plus.gitee.io/zh-CN/guide/design.html

代码规范

使用 EditorConfig + Prettier + ESLint 组合来实现代码规范化。

这样做带来好处:

  1. 解决团队之间代码不规范导致的可读性差和可维护性差的问题。
  2. 解决团队成员不同编辑器导致的编码规范不统一问题。
  3. 提前发现代码风格问题,给出对应规范提示,及时修复。 减少代码审查过程中反反复复的修改过程,节约时间。
  4. 自动格式化,统一编码风格,从此和脏乱差的代码说再见。
构建工具
Vite
运行要求

Vue 版本:3.0以上
node 版本:Vite 需要 Node.js 版本 &gt;= 12.0.0
浏览器:非IE浏览器

项目目录结构
讯享网

关于语法和Api的改变可以参见Vue官方文档:Vue2 迁移

全局 API

  1. 全局 Vue API 已更改为使用应用程序实例
  2. 全局和内部 API 已经被重构为支持 tree-shake

模板指令

  1. 组件上 v-model 用法已更改,以替换 v-bind.sync
  2. 和非 v-for 节点上的 key用法已更改
  3. 在同一元素上使用的 v-if 和 v-for 优先级已更改
  4. v-bind=“object” 现在排序敏感
  5. v-on:event.native 修饰符已移除
  6. v-for 中的 ref 不再注册 ref 数组

组件

  1. 只能使用普通函数创建函数式组件
  2. functional attribute 在单文件组件 (SFC) 的 和 functional 组件选项中被废弃
  3. 异步组件现在需要使用 defineAsyncComponent 方法来创建
  4. 组件事件现在需要在 emits 选项中声明

渲染函数

  1. 渲染函数 API 更改
  2. \(scopedSlots property 已移除&#xff0c;所有插槽都通过 \)slots 作为函数暴露
  3. \(listeners 被移除或整合到 \)attrs
  4. \(attrs 现在包含 class 和 style attribute</li></ol> <p>自定义元素</p> <ol><li>自定义元素检测现在在模板编译时执行</li><li>特殊的 is attribute 的使用被严格限制在被保留的 标签中</li></ol> <p>其他小改变</p> <ol><li>destroyed 生命周期选项被重命名为 unmounted</li><li>beforeDestroy 生命周期选项被重命名为 beforeUnmount</li><li>default prop 工厂函数不再可以访问 this 上下文</li><li>自定义指令的 API 已更改为与组件生命周期一致&#xff0c;且 binding.expression 已移除</li><li>data 选项应始终被声明为一个函数</li><li>来自 mixin 的 data 选项现在为浅合并</li><li>Attribute 强制策略已更改</li><li>一些过渡的 class 被重命名</li><li> 不再默认渲染包裹元素</li><li>当侦听一个数组时&#xff0c;只有当数组被替换时&#xff0c;回调才会触发&#xff0c;如果需要在变更时触发&#xff0c;则必须指定 deep 选项</li><li>没有特殊指令的标记 (v-if/else-if/else、v-for 或 v-slot) 的 现在被视为普通元素&#xff0c;并将渲染为原生的 元素&#xff0c;而不是渲染其内部内容。</li><li>已挂载的应用不会取代它所挂载的元素</li><li>生命周期的 hook: 事件前缀改为 vnode-</li></ol> <p>被移除的 API</p> <ol><li>keyCode 作为 v-on 修饰符的支持</li><li>off 和 \)once 实例方法
  5. 过滤器 (filter)
  6. 内联模板 attribute
  7. \(children 实例 property</li><li>propsData 选项</li><li>\)destroy 实例方法。用户不应再手动管理单个 Vue 组件的生命周期。
  8. 全局函数 set 和 delete 以及实例方法 \(set 和 \)delete。基于代理的变化检测已经不再需要它们了。

Element 和 Element Plus 框架也有所修改,请自行查阅 Element Plus 文档,对组件用法进行调整。

可能你会比较关系项目升级的耗时,以我公司项目为例,整个 Vue2 项目大概 200 多个页面,包括40多个表单。整个前端小组,5个人历时一个半月初步完成第一版,时间还是有点赶,主要在升级过程中不能开发新需求,怕积压了太多客户需求。上线后总体没有太多大问题,但是避免不了一些小问题,毕竟是整个项目的迁移,有问题马上解决就行了。不要耽误用户的时间。大概就这么多,感谢阅读!

小讯
上一篇 2025-04-28 14:01
下一篇 2025-06-13 11:19

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/171720.html