Vue2 快速过度 Vue3 教程 (后端学习)
隔好长一段时间没有写文章了,因为最近公司一个项目进度很赶,导致一直加班,没有时间空出来学习新的东西,这次趁着周末,赶紧补一下之前落下的一直想重新学一下整个大前端生态的想法,这次写一篇自己学习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函数,允许开发者将相关逻辑组织在一起,代码更清晰、更易复用。- 核心函数:
ref、reactive、computed、watch等。
- 核心函数:
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.$route 和 this.$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 进行了调整,主要体现在以下几个方面:
- 选项式 API(Options API)和 Vue 2 基本一致
- 组合式 API(Composition API)使用
onMounted、onUnmounted等函数 beforeDestroy变成onBeforeUnmount,destroyed变成onUnmounted
生命周期对比表
| 生命周期 | Vue 2 | Vue 3(Options API) | Vue 3(Composition API) |
|---|---|---|---|
| 创建前 | beforeCreate | beforeCreate | - |
| 创建后 | created | created | - |
| 挂载前 | beforeMount | beforeMount | - |
| 挂载后 | mounted | mounted | onMounted() |
| 更新前 | beforeUpdate | beforeUpdate | onBeforeUpdate() |
| 更新后 | updated | updated | onUpdated() |
| 销毁前 | beforeDestroy | beforeUnmount | onBeforeUnmount() |
| 销毁后 | destroyed | unmounted | onUnmounted() |
Vue 3 的变化:
beforeDestroy→onBeforeUnmountdestroyed→onUnmounted- Vue 3 组合式 API 使用
onMounted、onUnmounted代替mounted、destroyed。
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
相关文章:
Vue2 快速过度 Vue3 教程 (后端学习)
隔好长一段时间没有写文章了,因为最近公司一个项目进度很赶,导致一直加班,没有时间空出来学习新的东西,这次趁着周末,赶紧补一下之前落下的一直想重新学一下整个大前端生态的想法,这次写一篇自己学习Vue3的…...
供应链管理-职业规划:数字化供应链管理专家 / 供应链管理商业模式专家 / 供应链管理方案专家
一、背景阐述 依据联合国产业分类标准,工业体系被细致划分为41个工业大类、207个工业中类以及666个工业小类。中国凭借其独特的产业布局,成为全球唯一一个全面涵盖所有这些门类的国家,成功构建起独立且完备的现代工业体系。这一辉煌成就&…...
无状态版的DHCPv6是不是SLAAC? 笔记250405
无状态版的DHCPv6是不是SLAAC? 笔记250405 无状态版 DHCPv6 不是 SLAAC,但二者在 IPv6 网络中可协同工作。以下是核心区别与协作关系: 本质区别 特性SLAAC无状态 DHCPv6主要功能生成 IPv6 地址(基于路由器通告的前缀)分发 DNS、…...
遍历算法及其应用详解
李升伟 整理 什么是遍历? 遍历是指按照某种规则或顺序,系统地访问数据结构(如树、图等)中的每个节点一次且仅一次的过程。遍历是算法设计中的基本操作,用于访问、检查或修改数据结构中的所有元素。 主要遍历算法 1…...
Python 字典和集合(常见的映射方法)
本章内容的大纲如下: 常见的字典方法 如何处理查找不到的键 标准库中 dict 类型的变种set 和 frozenset 类型 散列表的工作原理 散列表带来的潜在影响(什么样的数据类型可作为键、不可预知的 顺序,等等) 常见的映射方法 映射类型…...
基于大模型的ALS预测与手术优化系统技术方案
目录 技术方案文档:基于大模型的ALS预测与手术优化系统1. 数据预处理与特征工程模块流程图伪代码2. 多模态融合预测模型模型架构图伪代码3. 术中实时监测与动态干预系统系统流程图伪代码4. 统计验证与可解释性模块验证流程图伪代码示例(SHAP分析)5. 健康教育与交互系统系统架…...
创建一个简单的HTML游戏站
创建一个简单的HTML游戏站涉及多个步骤,包括规划网站结构、设计用户界面、编写游戏逻辑以及测试和部署。下面是一个详细的步骤指南: 1. 规划网站结构 确定目标受众:了解你的目标用户群体。选择游戏类型:决定你要开发的游戏类型&…...
Matlab轴承故障信号仿真与故障分析
1.摘要 本文介绍了一个基于Matlab的轴承故障信号仿真与分析程序,旨在模拟和分析轴承内圈故障信号的特征。程序首先通过生成故障信号、共振信号和调制信号,添加噪声和离散化处理,构建模拟的振动信号,并保存相关数据。通过快速傅里…...
Linux 进程 | 概念 / 特征 / 状态 / 优先级 / 空间
注: 本文为 “Linux 进程” 相关文章合辑。 未整理去重。 Linux 进程概念(精讲) A little strawberry 于 2021-10-15 10:23:55 发布 基本概念 课本概念:程序的一个执行实例,正在执行的程序等。 内核观点ÿ…...
项目中如何防止超卖
什么是超卖?假如只剩下一个库存,却被多个订单买到了,简单理解就是库存不够了还能正常下单。 方案1:数据库行级锁 1. 实体类 Data TableName("product") public class Product {TableId(type IdType.AUTO)private Lon…...
重回全面发展亲自操刀
项目场景: 今年工作变动,优化后在一家做国有项目的私人公司安顿下来了。公司环境不如以前,但是好在瑞欣依然可以每天方便的买到。人文氛围挺好,就是工时感觉有点紧,可能长期从事产品迭代开发,一下子转变做项…...
3D珠宝渲染用什么软件比较好?渲染100邀请码1a12
印度珠宝商 Mohar Fine Jewels 和英国宝石商 Gemfields 在今年推出了合作珠宝系列——「Emeralds in Full Bloom」,它的灵感源自花草绽放的春季田野,共有 39 件作品,下面这个以植物为主题的开口手镯就是其中一件。 在数字时代,像这…...
【数据结构】邻接矩阵完全指南:原理、实现与稠密图优化技巧
邻接矩阵 导读一、图的存储结构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问题与解决总结 源码框架取自江协科技,在此基础上做扩展开发。 任务1 本文主要介绍利用stm32f103C8T6实现电位器控制PWM的占空比…...
ragflow开启https访问:添加证书后,使用浏览器还是有警告,如何解决?
如果在 Windows 系统中安装了 PEM 证书(使用方法一通过证书管理器 MMC 导入),但浏览器仍然提示安全警告,可能有以下几个原因及解决方法: 1. 证书未正确安装到受信任的存储位置 问题:如果证书被导入到错误的存储位置(如“个人”而非“受信任的根证书颁发机构”),浏览器…...
字符串——面试考察高频算法题
目录 转换成小写字母 字符串转化为整数 反转相关的问题 反转字符串 k个一组反转 仅仅反转字母 反转字符串里的单词 验证回文串 判断是否互为字符重排 最长公共前缀 字符串压缩问题 转换成小写字母 给你一个字符串 s ,将该字符串中的大写字母转换成相同的…...
Uniapp 集成极光推送(JPush)完整指南
文章目录 前言一、准备工作1. 注册极光开发者账号2. 创建应用3. Uniapp项目准备 二、集成极光推送插件方法一:使用UniPush(推荐)方法二:手动集成极光推送SDK 三、配置原生平台参数四、核心功能实现1. 获取RegistrationID2. 设置别…...
Plusar集群搭建-Ubuntu20.04-Winterm
1 背景 已经部署了Pulsar集群在生产上,新项目需要用到Pulsar。对Pulsar不熟,故搭建练手。 环境:Windows10vmwareUbuntu20.04,ssh工具使用的Winterm。 使用的是root账户,ubuntu防火墙都ufw disable了。 2 参考文档 集…...
selenium元素获取
from selenium import webdriver from selenium.webdriver.common.by import Bydriver webdriver.Chrome()driver.maximize_window()#最大化窗口 #隐式等待 driver.implicitly_wait(10)#打开网页 driver.get("https://www.zhipin.com/beijing/?kacity-sites-101010100&q…...
AI比人脑更强,因为被植入思维模型【50】邓克效应思维模型
giszz的理解:DK Effect,就是井底之蛙。这里有个启发,就是人的认知提升,有4个阶段,愚昧区、崩溃区、成长区、智慧区。也分别对应4个境界:自然境界、功利境界、道德境界、天地境界。我个人觉得自己刚刚过了崩…...
8、nRF52xx蓝牙学习(boards.h文件学习)
boards.h文件的代码如下: #ifndef BOARDS_H #define BOARDS_H#include "nrf_gpio.h" #include "nordic_common.h"#if defined(BOARD_NRF6310)#include "nrf6310.h" #elif defined(BOARD_PCA10000)#include "pca10000.h" #…...
声明文件.d.ts
在 TypeScript 中,.d.ts 文件是类型声明文件(Declaration Files),用于描述 JavaScript 库或模块的类型信息,但不包含具体实现。它们帮助 TypeScript 编译器进行类型检查,同时保持与纯 JavaScript 的兼容性。…...
java整合socket通信全流程
前言 大家好,由于工作上业务的需要,在java项目中引入了socket通信,特此记录一下,用以备份,本文章中的socket通信实现了,服务端与客户端的双向通讯,以及二者之间的心跳通信,服务端重启之后,客户端的自动重连功能。 原理 Socket通信是计算机网络中常用的一种通信机制…...
2025年常见渗透测试面试题-sql(题目+回答)
网络安全领域各种资源,学习文档,以及工具分享、前沿信息分享、POC、EXP分享。不定期分享各种好玩的项目及好用的工具,欢迎关注。 目录 SQLi 一、发现test.jsp?cid150 注入点的5种WebShell获取思路 1. 文件写入攻击 2. 日志文件劫持 3.…...
【RabbitMQ】队列模型
1.概述 RabbitMQ作为消息队列,有6种队列模型,分别在不同的场景进行使用,分别是Hello World,Work queues,Publish/Subscribe,Routing,Topics,RPC。 下面就分别对几个模型进行讲述。…...
StarRocks 助力首汽约车精细化运营
作者:任智红,首汽约车大数据负责人 更多交流,联系我们:https://wx.focussend.com/weComLink/mobileQrCodeLink/334%201%202/ffbe5 导读: 本文整理自首汽约车大数据负责人任智红在 StarRocks 年度峰会上的演讲…...
Springboot--Kafka客户端参数关键参数的调整方法
调整 Kafka 客户端参数需结合生产者、消费者和 Broker 的配置,以实现性能优化、可靠性保障或资源限制。以下是关键参数的调整方法和注意事项: 一、生产者参数调整 max.request.size 作用:限制单个请求的最大字节数(包括消…...
C++ 基类的虚析构函数与派生的析构函数关系
1、基类非虚析构函数,派生类析构函数,基类指针指向派生类 class Base { public:~Base() { // 非虚析构函数std::cout << "Base class destructor" << std::endl;} };class Derived : public Base { public:~Derived() { // 派生…...
解决Spring Boot上传默认限制文件大小和完善超限异常(若依框架)
文章目录 报错信息问题分析技术原理解决方法1️⃣调整 Spring Boot 配置文件2️⃣检查内嵌 Tomcat 配置(可选)3️⃣ 代码自定义配置(覆盖配置文件) 全局异常处理代码 报错信息 org.springframework.web.multipart.MaxUploadSizeE…...
AI平台如何实现推理?数算岛是一个开源的AI平台(主要用于管理和调度分布式AI训练和推理任务。)
数算岛是一个开源的AI平台,主要用于管理和调度分布式AI训练和推理任务。它基于Kubernetes构建,支持多种深度学习框架(如TensorFlow、PyTorch等)。以下是数算岛实现模型推理的核心原理、架构及具体实现步骤: 一、数算岛…...
