Vue2 快速过度 Vue3 教程 (后端学习)

news2025/7/16 0:18:43

隔好长一段时间没有写文章了,因为最近公司一个项目进度很赶,导致一直加班,没有时间空出来学习新的东西,这次趁着周末,赶紧补一下之前落下的一直想重新学一下整个大前端生态的想法,这次写一篇自己学习Vue3的笔记

从 Vue 2 到 Vue 3,Vue.js 进行了全面的升级,带来了许多新特性、性能优化和开发体验的提升。以下是 Vue 2 到 Vue 3 的主要变化和核心改进:

这里写目录标题

  • 一、Composition API
    • Vue 2 (Options API)
    • Vue 3 (Composition API)
  • 二、router
    • 创建 Router 实例的方式变化
      • Vue 2 (Vue Router 3)
      • Vue 3 (Vue Router 4)
    • 获取路由对象的方式
      • Vue 2
      • Vue 3
    • 动态路由的变化
      • Vue 2
      • Vue 3
  • 三、 全局变量和方法
    • 全局变量的定义
      • Vue 2:使用 Vue.prototype
      • Vue 3:使用 app.config.globalProperties
    • 全局方法的定义
      • Vue 2:使用 Vue.prototype
      • Vue 3:使用 globalProperties
  • 四、生命周期
    • 生命周期对比表
    • Options API 写法(Vue 3 仍支持 Vue 2 语法)
    • **Composition API 写法**
    • `watchEffect` 替代 `mounted + watch`

一、Composition API

  • Vue 2 的 Options API:Vue 2 使用 data、methods、computed 等选项来组织代码,逻辑分散在不同的选项中。

  • Vue 3 的 Composition API:引入了 setup 函数,允许开发者将相关逻辑组织在一起,代码更清晰、更易复用。

    • 核心函数:refreactivecomputedwatch 等。

Vue 3 引入了 Composition API,提供了更好的代码组织方式,特别适用于大型项目。

Vue 2 (Options API)

<template>
  <div>{{ count }}</div>
  <button @click="increment">增加</button>
</template>

<script>
export default {
  data() {
    return {
      count: 0,
      user: {
        name: "张三",
        age: 25
      }
    };
  },
  methods: {
    increment() {
      this.count++;
    }
  }
};
</script>

Vue 3 (Composition API)

Vue 3 使用 setup(),可以直接在script setup 里声明 ref 变量,而不需要 data methods 选项。代码更简洁,逻辑更清晰。Vue 3 提供了 reactive()ref() 作为新的响应式 API。

  • reactive() 适用于对象,使整个对象都变成响应式。

  • ref() 适用于基本数据类型,如 const count = ref(0)。

<template>
  <div>{{ count }}</div>
  <button @click="increment">增加</button>
</template>

<script setup>
import { ref,reactive  } from "vue";

const count = ref(0);

const increment = () => {
  count.value++;
};

const user = reactive({
  name: "张三",
  age: 25
});
</script>

二、router

Vue 3 的 vue-router 也进行了升级,主要是 Vue Router 4 替代了 Vue 2 中的 Vue Router 3。以下是它们的主要不同点及代码对比。

创建 Router 实例的方式变化

Vue 2 (Vue Router 3)

在 Vue 2 中,我们通常这样创建路由:

import Vue from "vue";
import VueRouter from "vue-router";
import Home from "./views/Home.vue";
import About from "./views/About.vue";

Vue.use(VueRouter);

const routes = [
  { path: "/", component: Home },
  { path: "/about", component: About },
];

const router = new VueRouter({
  mode: "history",
  routes,
});

export default router;

然后在 main.js 中:

import Vue from "vue";
import App from "./App.vue";
import router from "./router";

new Vue({
  router,
  render: (h) => h(App),
}).$mount("#app");

Vue 3 (Vue Router 4)

Vue 3 使用 createRouter() createWebHistory() 来替代 new VueRouter()

import { createRouter, createWebHistory } from "vue-router";
import Home from "./views/Home.vue";
import About from "./views/About.vue";

const routes = [
  { path: "/", component: Home },
  { path: "/about", component: About },
];

const router = createRouter({
  history: createWebHistory(),
  routes,
});

export default router;

然后在 main.js 中:

import { createApp } from "vue";
import App from "./App.vue";
import router from "./router";

const app = createApp(App);
app.use(router);
app.mount("#app");

区别:

  • Vue.use(VueRouter) 在 Vue 3 里不再使用,而是 app.use(router)。
  • createRouter() 代替了 new VueRouter()。
  • createWebHistory() 代替了 mode: “history”。

获取路由对象的方式

Vue 2

this.$route.path; // 获取当前路径
this.$router.push('/about'); // 跳转到 about 页面

Vue 3

Vue 3 仍然支持 this.$routethis.$router,但推荐在 Composition API 里使用 useRoute()useRouter()

<script setup>
import { useRoute, useRouter } from "vue-router";

const route = useRoute();
const router = useRouter();

console.log(route.path); // 获取当前路径

const goToAbout = () => {
  router.push("/about"); // 编程式导航
};
</script>

动态路由的变化

Vue 2

在 Vue 2 中,我们可以用 this.$route.params 获取动态参数:

const userId = this.$route.params.id; 

Vue 3

在 Vue 3 中,推荐使用 useRoute():

import { useRoute } from "vue-router";

const route = useRoute();
const userId = route.params.id;

三、 全局变量和方法

全局变量的定义

Vue 2:使用 Vue.prototype

在 Vue 2 中,我们通常使用 Vue.prototype 来定义全局变量:

import Vue from "vue";

Vue.prototype.$globalVar = "我是全局变量";

new Vue({
  el: "#app",
  created() {
    console.log(this.$globalVar); // 输出: 我是全局变量
  }
});

Vue 3:使用 app.config.globalProperties

Vue 3 移除了 Vue.prototype,改用 globalProperties:

import { createApp } from "vue";
import App from "./App.vue";

const app = createApp(App);
app.config.globalProperties.$globalVar = "我是全局变量";
app.mount("#app");

使用方式(在组件内访问):

<script setup>
import { getCurrentInstance } from "vue";

const { proxy } = getCurrentInstance();
console.log(proxy.$globalVar); // 输出: 我是全局变量
</script>

全局方法的定义

Vue 2:使用 Vue.prototype

Vue.prototype.$greet = function(name) {
  return `你好, ${name}`;
};

new Vue({
  created() {
    console.log(this.$greet("张三")); // 输出: 你好, 张三
  }
});

Vue 3:使用 globalProperties

app.config.globalProperties.$greet = (name) => `你好, ${name}`;

在组件内使用:

<script setup>
import { getCurrentInstance } from "vue";

const { proxy } = getCurrentInstance();
console.log(proxy.$greet("张三")); // 输出: 你好, 张三
</script>

四、生命周期

Vue 3 的生命周期钩子(Lifecycle Hooks)相较于 Vue 2 进行了调整,主要体现在以下几个方面:

  1. 选项式 API(Options API)和 Vue 2 基本一致
  2. 组合式 API(Composition API)使用 onMountedonUnmounted 等函数
  3. beforeDestroy 变成 onBeforeUnmountdestroyed 变成 onUnmounted

生命周期对比表

生命周期Vue 2Vue 3(Options API)Vue 3(Composition API)
创建前beforeCreatebeforeCreate-
创建后createdcreated-
挂载前beforeMountbeforeMount-
挂载后mountedmountedonMounted()
更新前beforeUpdatebeforeUpdateonBeforeUpdate()
更新后updatedupdatedonUpdated()
销毁前beforeDestroybeforeUnmountonBeforeUnmount()
销毁后destroyedunmountedonUnmounted()

Vue 3 的变化:

  • beforeDestroyonBeforeUnmount
  • destroyedonUnmounted
  • Vue 3 组合式 API 使用 onMountedonUnmounted 代替 mounteddestroyed

Options API 写法(Vue 3 仍支持 Vue 2 语法)

Vue 3 仍然支持 传统的生命周期写法:

<script>
export default {
  data() {
    return {
      message: "Hello Vue 3"
    };
  },
  beforeCreate() {
    console.log("beforeCreate");
  },
  created() {
    console.log("created");
  },
  beforeMount() {
    console.log("beforeMount");
  },
  mounted() {
    console.log("mounted");
  },
  beforeUpdate() {
    console.log("beforeUpdate");
  },
  updated() {
    console.log("updated");
  },
  beforeUnmount() {
    console.log("beforeUnmount");
  },
  unmounted() {
    console.log("unmounted");
  }
};
</script>

区别:

  • beforeDestroy 变成了 beforeUnmount
  • destroyed 变成了 unmounted

Composition API 写法

在 Vue 3 组合式 API 里,生命周期钩子变成了 onXxx() 形式:

<script setup>
import { onMounted, onUnmounted, ref } from "vue";

const message = ref("Hello Vue 3");

onMounted(() => {
  console.log("组件已挂载");
});

onUnmounted(() => {
  console.log("组件已卸载");
});
</script>

区别:

  • 直接使用 onMounted(),不需要 mounted()
  • 适用于 setup() 语法,更简洁。

watchEffect 替代 mounted + watch

Vue 2 中,通常需要在 mounted()watch 监听数据:

<script>
export default {
  data() {
    return {
      count: 0
    };
  },
  mounted() {
    this.$watch("count", (newValue, oldValue) => {
      console.log("count 变化:", oldValue, "=>", newValue);
    });
  }
};
</script>

Vue 3 推荐用 watchEffect()

<script setup>
import { ref, watchEffect } from "vue";

const count = ref(0);

watchEffect(() => {
  console.log("count 变化:", count.value);
});
</script>

区别:

  • watchEffect() 会自动追踪 count.value,不需要手动指定。

推荐视频
https://www.bilibili.com/video/BV14g41117HB?spm_id_from=333.788.videopod.episodes&vd_source=036b64d827caa25b16f82980eccb482a&p=2

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python 字典和集合(常见的映射方法)

本章内容的大纲如下&#xff1a; 常见的字典方法 如何处理查找不到的键 标准库中 dict 类型的变种set 和 frozenset 类型 散列表的工作原理 散列表带来的潜在影响&#xff08;什么样的数据类型可作为键、不可预知的 顺序&#xff0c;等等&#xff09; 常见的映射方法 映射类型…

Matlab轴承故障信号仿真与故障分析

1.摘要 本文介绍了一个基于Matlab的轴承故障信号仿真与分析程序&#xff0c;旨在模拟和分析轴承内圈故障信号的特征。程序首先通过生成故障信号、共振信号和调制信号&#xff0c;添加噪声和离散化处理&#xff0c;构建模拟的振动信号&#xff0c;并保存相关数据。通过快速傅里…

Linux 进程 | 概念 / 特征 / 状态 / 优先级 / 空间

注&#xff1a; 本文为 “Linux 进程” 相关文章合辑。 未整理去重。 Linux 进程概念&#xff08;精讲&#xff09; A little strawberry 于 2021-10-15 10:23:55 发布 基本概念 课本概念&#xff1a;程序的一个执行实例&#xff0c;正在执行的程序等。 内核观点&#xff…

重回全面发展亲自操刀

项目场景&#xff1a; 今年工作变动&#xff0c;优化后在一家做国有项目的私人公司安顿下来了。公司环境不如以前&#xff0c;但是好在瑞欣依然可以每天方便的买到。人文氛围挺好&#xff0c;就是工时感觉有点紧&#xff0c;可能长期从事产品迭代开发&#xff0c;一下子转变做项…

3D珠宝渲染用什么软件比较好?渲染100邀请码1a12

印度珠宝商 Mohar Fine Jewels 和英国宝石商 Gemfields 在今年推出了合作珠宝系列——「Emeralds in Full Bloom」&#xff0c;它的灵感源自花草绽放的春季田野&#xff0c;共有 39 件作品&#xff0c;下面这个以植物为主题的开口手镯就是其中一件。 在数字时代&#xff0c;像这…

【数据结构】邻接矩阵完全指南:原理、实现与稠密图优化技巧​

邻接矩阵 导读一、图的存储结构1.1 分类 二、邻接矩阵法2.1 邻接矩阵2.2 邻接矩阵存储网 三、邻接矩阵的存储结构四、算法评价4.1 时间复杂度4.2 空间复杂度 五、邻接矩阵的特点5.1 特点1解析5.2 特点2解析5.3 特点3解析5.4 特点4解析5.5 特点5解析5.6 特点6解析 结语 导读 大…

【嵌入式-stm32电位器控制以及旋转编码器控制LED亮暗】

嵌入式-stm32电位器控制LED亮暗 任务1代码1Key.cKey.hTimer.cTimer.hPWM.cPWM.hmain.c 实验现象1任务2代码2Key.cKey.hmain.c 实验现象2问题与解决总结 源码框架取自江协科技&#xff0c;在此基础上做扩展开发。 任务1 本文主要介绍利用stm32f103C8T6实现电位器控制PWM的占空比…

Uniapp 集成极光推送(JPush)完整指南

文章目录 前言一、准备工作1. 注册极光开发者账号2. 创建应用3. Uniapp项目准备 二、集成极光推送插件方法一&#xff1a;使用UniPush&#xff08;推荐&#xff09;方法二&#xff1a;手动集成极光推送SDK 三、配置原生平台参数四、核心功能实现1. 获取RegistrationID2. 设置别…

2025年常见渗透测试面试题-sql(题目+回答)

网络安全领域各种资源&#xff0c;学习文档&#xff0c;以及工具分享、前沿信息分享、POC、EXP分享。不定期分享各种好玩的项目及好用的工具&#xff0c;欢迎关注。 目录 SQLi 一、发现test.jsp?cid150 注入点的5种WebShell获取思路 1. 文件写入攻击 2. 日志文件劫持 3.…

【RabbitMQ】队列模型

1.概述 RabbitMQ作为消息队列&#xff0c;有6种队列模型&#xff0c;分别在不同的场景进行使用&#xff0c;分别是Hello World&#xff0c;Work queues&#xff0c;Publish/Subscribe&#xff0c;Routing&#xff0c;Topics&#xff0c;RPC。 下面就分别对几个模型进行讲述。…

StarRocks 助力首汽约车精细化运营

作者&#xff1a;任智红&#xff0c;首汽约车大数据负责人 更多交流&#xff0c;联系我们&#xff1a;https://wx.focussend.com/weComLink/mobileQrCodeLink/334%201%202/ffbe5 导读&#xff1a; 本文整理自首汽约车大数据负责人任智红在 StarRocks 年度峰会上的演讲&#xf…

痉挛性斜颈康复助力:饮食调养指南

痉挛性斜颈患者除了积极治疗&#xff0c;合理饮食也能辅助缓解症状&#xff0c;提升生活质量。其健康饮食可从以下方面着手&#xff1a; 高蛋白质食物助力肌肉修复 痉挛性斜颈会导致颈部肌肉异常收缩&#xff0c;消耗较多能量&#xff0c;蛋白质有助于肌肉的修复与维持。日常可…

mysql镜像创建docker容器,及其可能遇到的问题

前提&#xff0c;已经弄好基本的docker服务了。 一、基本流程 1、目录准备 我自己的资料喜欢放在 /data 目录下&#xff0c;所以老规矩&#xff1a; 先进入 /data 目录&#xff1a; cd /data 创建 mysql 目录并进入&#xff1a; mkdir mysql cd mysql 2、镜像查找 docke…

JavaEE——线程的状态

目录 前言1. NEW2. TERMINATED3. RUNNABLE4. 三种阻塞状态总结 前言 本篇文章来讲解线程的几种状态。在Java中&#xff0c;线程的状态是一个枚举类型&#xff0c;Thread.State。其中一共分为了六个状态。分别为&#xff1a;NEW,RUNNABLE,BLOCKED,WAITING,TIMED_WAITING, TERMI…

RuntimeError: Error(s) in loading state_dict for ChartParser

一 bug错误 最近使用千问大模型有一个bug&#xff0c;报错信息如下 raise RuntimeError(Error(s) in loading state_dict for {}:\n\t{}.format( RuntimeError: Error(s) in loading state_dict for ChartParser:Unexpected key(s) in state_dict: "pretrained_model.em…

2025 年安徽交安安全员考试:利用记忆宫殿强化记忆​

安徽考生在面对交安安全员考试繁杂的知识点时&#xff0c;记忆宫殿是强大的记忆工具。选择一个熟悉且空间结构清晰的场所作为记忆宫殿&#xff0c;如自己居住的房屋。将房屋的不同区域&#xff0c;如客厅、卧室、厨房等&#xff0c;分别对应不同知识板块&#xff0c;像客厅对应…

安全编码课程 实验6 整数安全

实验项目 实现安全计数器&#xff1a;实现 Counter 结构&#xff0c;确保计数范围为 0~100。 实验要求&#xff1a; 1、使用 struct 封装计数值value&#xff1b; 2、计数器初值为 0&#xff1b; 3、increment() 方法增加计数&#xff0c;但不能超过 100&#xff1b; 4、decrem…

解决上传PDF、视频、音频等格式文件到FTP站点时报错“将文件复制到FTP服务器时发生错误。请检查是否有权限将文件放到该服务器上”问题

一、问题描述 可以将文本文件(.txt格式),图像文件(.jpg、.png等格式)上传到我们的FTP服务器上;但是上传一些PDF文件、视频等文件时就会报错“ 将文件复制到FTP服务器时发生错误。请检查是否有权限将文件放到该服务器上。 详细信息: 200 Type set to l. 227 Entering Pas…

【Linux操作系统】:信号

Linux操作系统下的信号 一、引言 首先我们可以简单理解一下信号的概念&#xff0c;信号&#xff0c;顾名思义&#xff0c;就是我们操作系统发送给进程的消息。举个简单的例子&#xff0c;我们在写C/C程序的时候&#xff0c;当执行a / 0类似的操作的时候&#xff0c;程序直接就挂…

经典频域分析法(Bode图、Nyquist判据) —— 理论、案例与交互式 GUI 实现

目录 经典频域分析法(Bode图、Nyquist判据) —— 理论、案例与交互式 GUI 实现一、引言二、经典频域分析方法的基本原理2.1 Bode 图分析2.2 Nyquist 判据三、数学建模与公式推导3.1 一阶系统的频域响应3.2 多极系统的 Bode 图绘制3.3 Nyquist 判据的数学描述四、经典频域分析…