Vue 2.x 项目升级到 Vue 3详细指南【总结版】

文章目录

  • 0.前言
  • 1.升级教程
    • 1.1. 升级 Vue CLI:
    • 1.2. 安装 Vue 3:
    • 1.3. 更新 Vue 组件:
    • 1.4. 迁移全局 API:
    • 1.5. 迁移路由和状态管理器:
    • 1.6. 迁移 TypeScript:
    • 1.7. 迁移测试代码:
  • 2.迁移总结
    • 2.0. ==这一项很关键==
    • 2.1. 语法变化
    • 2.2. 插件和库的兼容性
    • 2.3. TypeScript 支持
    • 2.4. 升级顺序
    • 2.5. 测试和调试
  • 3.官方文档和其他参考资源:

0.前言

在这里插入图片描述

首先提个问题,大家公司的Vue前端项目目前使用的版本是多少呢,是否已经在计划升级版本或者进行重构,那么如果有这个计划,那么这篇文章将是具有一定指导意义,至少在你的升级改造的工时评估方面有着借鉴意义。

随着Vue 版本的不断升级迭代,目前基本上有着稳定开发团队和技术积累的公司,陆陆续续将前端服务的Vue版本从Vue2.x 升级Vue3。因为Vue3 它带来了许多新特性和改进,例如更快的渲染速度、更好的类型推导、更好的组合 API 等等。如果你正在使用 Vue 2.x,升级到 Vue 3 可以让你的项目获得这些新特性和改进,并且更好地适应未来的发展。然而,Vue 3 与 Vue 2.x 在语法和一些核心概念上有一些重大变化,因此升级 Vue 3 可能需要一些额外的工作。本指南将为你提供一些有关如何将 Vue 2.x 项目升级到 Vue 3 的详细说明和指导,希望能够帮助你平滑地进行升级。

1.升级教程

1.1. 升级 Vue CLI:

如果你的项目是使用 Vue CLI 创建的,则需要升级到最新版本的 Vue CLI(3.0.0 及以上),以便支持 Vue 3。可以使用以下命令升级 Vue CLI:

npm install -g @vue/cli

yarn global add @vue/cli

1.2. 安装 Vue 3:

使用 npm 或 yarn 安装最新版本的 Vue 3:

npm install vue@next

yarn add vue@next

1.3. 更新 Vue 组件:

在 Vue 3 中,一些属性和选项被重命名或删除,需要更新组件代码。

  • v-bind=“$listeners” 替换为 v-bind=“listeners”

    在 Vue 2.x 中,可以使用 v-bind=“$listeners” 将所有父组件传递的事件监听器绑定到子组件上,但是在 Vue 3 中,这种语法被弃用了,需要改为 v-bind=“listeners”。

  • v-bind=“$attrs” 替换为 v-bind=“attrs”

    在 Vue 2.x 中,可以使用 v-bind=“$attrs” 将所有非 prop 的父组件属性绑定到子组件上,但是在 Vue 3 中,需要改为 v-bind=“attrs”

  • v-on:click.native 替换为 @click.native

    在 Vue 2.x 中,可以使用 v-on:click.native 绑定原生 DOM 事件,但是在 Vue 3 中,需要改为 @click.native

  • v-on:keyup.enter 替换为 @keyup.enter
    在 Vue 2.x 中,可以使用 v-on:keyup.enter 绑定键盘事件,但是在 Vue 3 中,需要改为 @keyup.enter。

  • v-on:keyup.13 替换为 @keyup.13

    在 Vue 2.x 中,可以使用 v-on:keyup.13 绑定键盘事件,但是在 Vue 3 中,不再支持这种语法,需要改为 @keyup.13。

  • v-on:keyup 替换为 @keyup
    在 Vue 2.x 中,可以使用 v-on:keyup 绑定键盘事件,但是在 Vue 3 中,需要改为 @keyup。

1.4. 迁移全局 API:

Vue 3 中全局 API 的使用方式也有所改变。例如:

  • Vue.filter 替换为 app.config.globalProperties.$filter

    在 Vue 2.x 中,可以使用 Vue.filter 注册全局过滤器,但是在 Vue 3 中,需要使用 app.config.globalProperties.$filter。

  • Vue.directive 替换为 app.directive

    在 Vue 2.x 中,可以使用 Vue.directive 注册全局指令,但是在 Vue 3 中,需要使用 app.directive。

  • Vue.mixin 替换为 app.mixin

    在 Vue 2.x 中,可以使用 Vue.mixin 全局混入选项,但是在 Vue 3 中,需要使用 app.mixin。

1.5. 迁移路由和状态管理器:

如果你的项目中使用了 Vue Router 和 Vuex 等状态管理器,需要将其升级到最新版本,以适配 Vue 3。

  • Vue Router:

    Vue Router 4.x 支持 Vue 3,需要将 Vue Router 和 Vue 升级到最新版本,然后更新路由的 API 和语法,例如:

    • router-link 替换为 RouterLink
    • v-bind=“ r o u t e " 替换为 : t o = " route" 替换为 :to=" route"替换为:to="route”
    • $router.push 替换为 router.push
  • Vuex:

    Vuex 4.x 支持 Vue 3,需要将 Vuex 和 Vue 升级到最新版本,然后更新状态管理器的 API 和语法,例如:

    • store.subscribe 替换为 store.watch
    • mapState 替换为 useStore/mapState

1.6. 迁移 TypeScript:

如果你的项目使用 TypeScript,需要更新 TypeScript 版本并进行相应的配置和迁移。

  • TypeScript 版本:

    Vue 3 需要 TypeScript 3.9 及以上版本。

  • 配置文件:
    需要更新 TypeScript 配置文件(tsconfig.json)中的编译选项,例如:

    {
      "compilerOptions": {
        "target": "esnext",
        "module": "esnext",
        "moduleResolution": "node",
        "jsx": "preserve",
        "strict": true,
        "esModuleInterop": true,
        "skipLibCheck": true,
        "forceConsistentCasingInFileNames": true,
        "noImplicitReturns": true,
        "noFallthroughCasesInSwitch": true,
        "allowSyntheticDefaultImports": true,
        "resolveJsonModule": true,
        "isolatedModules": true,
        "noEmit": true,
        "types": [
          "webpack-env",
          "@types/node",
          "@vue/cli-plugin-babel/types",
          "@vue/cli-plugin-eslint/types",
          "@vue/cli-service"
        ]
      },
      "include": ["src/**/*"],
      "exclude": ["node_modules", "dist"]
    }
    
  • 类型定义文件:

    Vue 3 中的类型定义文件(.d.ts)有所改变,需要将其更新为最新的版本。

1.7. 迁移测试代码:

如果你的项目中有测试代码,需要更新测试框架和测试代码,以适配 Vue 3。

  • 测试框架:

    更新测试框架到最新版本,例如 Jest 27.x、Mocha 9.x 等。

  • 测试代码:

    更新测试代码,例如:

 - import { mount } from '@vue/test-utils' 替换为 import { mount } from 'vue-test-utils'
 - Vue.extend 替换为 defineComponent
 - wrapper.vm.$emit 替换为 wrapper.trigger

将 Vue 2.x 项目升级到 Vue 3 需要更新组件代码、全局 API、路由和状态管理器、TypeScript 配置和测试代码等。如果你对迁移过程不确定,可以先在一个新的项目中尝试升级,以便在实际项目中更好地适配 Vue 3。

2.迁移总结

2.0. 这一项很关键

vue2.x升级到vue3 做好充分的准备和团队,以及领导沟通清楚,步骤以及面临的风险,以及应急准备,以及知识储备和人员储备。就比如搞了一半发现领导根本对vue升级的急迫性没那么强烈,中途给你把资源撤了,半拉子烂摊子毁在你的手里,瞬间挫败感笼上心头。记住资源是团队作战中很重要的事情,提前给团队和领导信心和目标。在升级之前,需要做好充分的准备和规划。有的时候干成一件事,也许技术上根本不是障碍

下面只是一些技术上的总结和技术事项,都好解决。

2.1. 语法变化

Vue 3 中的语法与 Vue 2.x 有一些重大变化,例如使用 createApp 替代了 new Vue,使用 setup 替代了 datamethods 等等。因此,需要花费一些时间来学习新语法和调整现有代码。

2.2. 插件和库的兼容性

一些 Vue 2.x 插件和库可能不兼容 Vue 3,需要更新或替换。在升级之前,需要检查你的依赖项是否与 Vue 3 兼容,并相应地做出调整。

2.3. TypeScript 支持

Vue 3 对 TypeScript 的支持更加完善,因此如果你的项目中使用了 TypeScript,升级到 Vue 3 可能需要一些额外的注意事项,例如更改类型定义和配置文件等等。

2.4. 升级顺序

如果你的项目依赖于其他库或框架,例如 Vuex、Vue Router 等等,需要在升级 Vue 3 之前先升级这些库或框架,以确保整个项目能够顺利升级。

2.5. 测试和调试

在升级之后,需要进行一些测试和调试来确保项目的稳定性和正确性。这可能需要一些额外的时间和精力。

在这里插入图片描述

3.官方文档和其他参考资源:

·如果你想自己去了解,那么我整理了这些资源可能对你有帮助

  1. Vue 3 官方文档:https://v3.cn.vuejs.org/ ↗
  2. Vue 3 Composition API 文档:https://v3.vuejs.org/guide/composition-api-introduction.html ↗
  3. Vue 3 TypeScript 支持文档:https://v3.vuejs.org/guide/typescript-support.html ↗
  4. Vue CLI 3 文档:https://cli.vuejs.org/ ↗
  5. Vue Router 4 文档:https://next.router.vuejs.org/ ↗
  6. Vuex 4 文档:https://next.vuex.vuejs.org/ ↗
  7. Vue 3 源码:https://github.com/vuejs/vue-next ↗
  8. Vue 3 生态系统:https://v3.ecosystem.vuejs.org/ ↗
  9. Vue Mastery 课程:https://www.vuemastery.com/courses/vue-3-essentials ↗
  10. Vue.js 开发者社区:https://forum.vuejs.org/ ↗

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/55946.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

ESP32cam系列教程003:ESP32cam实现远程 HTTP_OTA 自动升级

文章目录 1.什么是 OTA2. ESP32cam HTTP_OTA 本地准备2.1 HTTP OTA 升级原理2.2 开发板本地基准程序(程序版本:1_0_0)2.3 开发板升级程序(程序版本:1_0_1)2.4 本地 HTTP_OTA 升级测试2.4.1 本地运行一个 HT…

使用Linux部署Jpress博客系统

环境要求 linux系统:我使用的操作系统是CentOS7 数据库:mysql,也可以使用mariadb jdk:与你的Linux操作系统能兼容的版本 tomcat:我使用的是tomcat8版本 如果没有数据库,请先自行下载 如果没有安装jdk…

Agile manifesto principle (敏捷宣言的原则)

Agile在管理中越来越受推崇,最初是由于传统的软件开发管理方式(瀑布模型)面对日益复杂的需求,无法Delivery令人满意的结果,经过总结探索,2001年,由行业代表在一次聚会中提出Agile敏捷mainfesto&…

RK3588开发板 (armsom-w3) 之 USB摄像头图像预览

硬件准备 RK3588开发板(armsom-w3)、USB摄像头(罗技高清网络摄像机 C93)、1000M光纤 、 串口调试工具 v4l2采集画面 v4l2-ctl是一个用于Linux系统的命令行实用程序,用于控制视频4 Linux 2(V4L2&#xff0…

P1257 平面上的最接近点对

题目 思路 详见加强加强版 代码 #include<bits/stdc.h> using namespace std; #define int long long const int maxn4e510; pair<int,int> a[maxn]; int n; double d1e16; pair<int,int> vl[maxn],vr[maxn]; void read() { cin>>n;for(int i1;i<…

(一)基于Spring Reactor框架响应式异步编程|道法术器

Spring WebFlux 响应式异步编程|道法术器(一) Spring WeFlux响应式编程整合另一种方案|道法术器(二) R2DBC简介 Spring data R2DBC是更大的Spring data 系列的一部分&#xff0c;它使得实现基于R2DBC的存储库变得容易。R2DBC代表反应式关系数据库连接&#xff0c;这是一种使用…

SpringBoot统一功能处理

我们要实现以下3个目标&#xff1a; 统一用户登录权限统一数据格式返回统一异常处理 1.用户的登录权限校验 1.1Spring AOP用户统一登录验证问题 Aspect Component public class UserAspect {// 定义切点controller包下、子孙包下所有类的所有方法Pointcut("execution(…

浅析大数据时代下的视频技术发展趋势以及AI加持下视频场景应用

视频技术的发展可以追溯到19世纪初期的早期实验。到20世纪初期&#xff0c;电视技术的发明和普及促进了视频技术的进一步发展。 1&#xff09;数字化&#xff1a;数字化技术的发明和发展使得视频技术更加先进。数字电视信号具有更高的清晰度和更大的带宽&#xff0c;可以更快地…

【李宏毅机器学习·学习笔记】Deep Learning General Guidance

本节课可视为机器学习系列课程的一个前期攻略&#xff0c;这节课主要对Machine Learning 的框架进行了简单的介绍&#xff1b;并以training data上的loss大小为切入点&#xff0c;介绍了几种常见的在模型训练的过程中容易出现的情况。 课程视频&#xff1a; Youtube&#xff1…

青少年软件编程(Python六级)等级考试试卷(2022年9月)

青少年软件编程&#xff08;Python六级&#xff09;等级考试试卷&#xff08;2022年9月&#xff09; 第 1 题 单选题 以下关于Python二维数据的描述中&#xff0c;错误的是&#xff1f;&#xff08; &#xff09; A. 表格数据属于二维数据&#xff0c;由整数索引的数据构成 …

Appium+python自动化(二十八)- 高级滑动(超详解)

高级溜冰的滑动 滑动操作一般是两点之间的滑动&#xff0c;这种滑动在这里称其为低级的溜冰滑动&#xff1b;就是上一节给小伙伴们分享的。然而实际使用过程中用户可能要进行一些多点连续滑动操作。如九宫格滑动操作&#xff0c;连续拖动图片移动等场景。那么这种高级绚丽的溜…

银河麒麟V10 飞腾 Qt环境搭建

采用在线安装方式&#xff1a; 1、在线安装qt组件 sudo apt-get install qt5-* 2、在线安装qt creator sudo apt-get install qtcreator 以上简单两步安装完成后&#xff0c;新建项目已经可以编译过&#xff0c;但ClangCodeModel会报错如下图 the code model could not parse …

docker—springboot服务通信

文章目录 docker—springboot服务通信一、方式1、host 二、坑点末、参考资料 docker—springboot服务通信 一、方式 1、host 步骤&#xff1a; host文件增加域名解析&#xff1a; 127.0.0.1 rabbitmqapplication.yml&#xff1a; application.yml中&#xff0c;连接方式使用…

matlab使用教程(7)—基本画图函数

1.创建绘图 plot 函数具有不同的形式&#xff0c;具体取决于输入参数。 • 如果 y 是向量&#xff0c; plot(y) 会生成 y 元素与 y 元素索引的分段线图。 • 如果有两个向量被指定为参数&#xff0c; plot(x,y) 会生成 y 对 x 的图形。 使用冒号运算符创建从 0 至 2…

python-网络爬虫.BS4

BS4 Beautiful Soup 是一个可以从HTML或XML文件中提取数据的Python库&#xff0c; 它能够通过你喜欢的转换器实现惯用的文档导航、查找、修改文档的方 式。 Beautiful Soup 4 官方文档&#xff1a;https://www.crummy.com/software/BeautifulSoup/bs4/doc.zh/ 帮助手册&…

devops(前端)

1.前言 前端的打包流程和后端的流程是一样的&#xff0c;只是打包的环境和制作的镜像有所不同&#xff0c;前端需要使用nodejs环境打包&#xff0c;镜像也是使用nginx镜像&#xff0c;因为用的是k8s的pod运行镜像&#xff0c;还需要使用configmap挂载nginx的配置&#xff0c;一…

CDH基于Kerberos开启身份验证实践总结

CDH基于Kerberos开启身份验证实践总结 前言简介Kerberos是什么Kerberos解决什么问题 Kerberos基本概念Kerberos认证流程Kerberos基本配置principalkeytabkrb5.confkdc.confkadm5.aclkerberos数据库 访问示例数据库访问信息 其他kerberos常用命令[Git Bash支持make命令](https:/…

【计算机网络】11、网络连通性:ping、traceroute、nslookup

文章目录 一、ping1.1 禁 ping 二、traceroute三、nslookup3.1 非交互模式3.2 交互模式 注意&#xff0c;测试网络连通性时&#xff0c;有的机器无法 ping 通&#xff0c;但可能 telnet 能通。不要因为无法 ping 通就放弃尝试。 一、ping 1.1 禁 ping 禁 ping 是通过忽略 IC…

SpringBoot 统⼀功能处理

目录 前言 1.⽤户登录权限效验 1.1、最初⽤户登录效验 1.2、Spring AOP ⽤户统⼀登录验证的问题 1.3、Spring 拦截器 了解 创建一个 Spring 拦截器 的流程 1、 创建自定义拦截器&#xff0c;实现 HandlerInterceptor 接⼝的preHandle&#xff08;执⾏具体⽅法之前的预处理…

day17 | 654.最大的二叉树 617.合并二叉树 700.二叉搜索树中的搜索 98.验证二叉搜索树

文章目录 一、最大的二叉树二、合并二叉树三、二叉搜索树中的搜索四、验证二叉搜索树 一、最大的二叉树 654.最大的二叉树 构建二叉树的题目&#xff0c;都用前序遍历。 因为我们一定要先构建根节点&#xff0c;才能继续向后构建。 递归函数的参数和返回值&#xff1a; Tree…