重生之我在学Vue--第2天 Vue 3 Composition API 与响应式系统
重生之我在学Vue–第2天 Vue 3 Composition API 与响应式系统
文章目录
- 重生之我在学Vue--第2天 Vue 3 Composition API 与响应式系统
- 前言
- 一、Composition API 核心概念
- 1.1 什么是 Composition API?
- 1.2 Composition API 的核心工具
- 1.3 基础用法示例
- 二、响应式系统
- 2.1 响应式工具
- 1. `ref`
- 2. `reactive`
- 3. `computed`
- 2.2 响应式系统的核心原理
- 2.3 响应式数据的监听
- 1. 使用 `watch`
- 2. 使用 `watchEffect`
- 三、案例实践:Todo 应用
- 功能
- 代码实现
前言
Vue 3 引入了 Composition API,它是一种新的组件逻辑组织方式,旨在解决 Vue 2 中 Options API 难以管理复杂逻辑的问题。通过 Composition API,我们可以更灵活地组织代码、复用逻辑,并充分利用 Vue 3 的响应式系统。
Vue3 官方中文文档传送点: 简介 | Vue.js
Vue3 的中文官方文档学习笔记很全还有练习场,推荐去官网学习
Vue前端成仙之路:Vue 前端成仙之路_野生的程序媛的博客-CSDN博客
GO后端成神之路:Go 后端成神之路_野生的程序媛的博客-CSDN博客
一、Composition API 核心概念
1.1 什么是 Composition API?
Composition API 是 Vue 3 提供的一组新的 API,用于定义组件的逻辑和状态。它的核心是 setup 函数,所有组件的逻辑都可以在 setup 中定义。
export default {setup() {// 在这里定义组件逻辑return {};},
};
1.2 Composition API 的核心工具
以下是 Composition API 的核心工具和它们的作用:
| 工具 | 作用 |
|---|---|
ref | 创建响应式的基本数据类型(如字符串、数字、布尔值)。 |
reactive | 创建响应式的复杂对象(如数组、对象)。 |
computed | 创建基于其他响应式数据的计算属性。 |
watch | 监听响应式数据的变化并执行副作用。 |
watchEffect | 自动追踪响应式数据的依赖并执行副作用。 |
onMounted | 组件挂载时的生命周期钩子。 |
onUnmounted | 组件卸载时的生命周期钩子。 |
provide/inject | 实现跨组件的数据共享(类似 Vue 2 的 provide/inject)。 |
1.3 基础用法示例
以下是一个简单的计数器示例,展示了如何使用 ref 和 onMounted。
<template><div><h1>{{ count }}</h1><button @click="increment">增加</button></div>
</template><script>
import { ref, onMounted } from 'vue';export default {setup() {const count = ref(0);const increment = () => {count.value++;};onMounted(() => {console.log('组件已挂载');});return {count,increment,};},
};
</script>
代码解析:
- 响应式数据
count:- 使用
ref创建了一个响应式数据count,初始值为0。 - 通过
count.value可以访问和修改其值。 - 在模板中,
{{ count }}会自动解包ref的值(无需显式加.value)。
- 使用
- 事件绑定:
- 使用
@click绑定一个点击事件,当按钮被点击时,执行increment方法。 increment方法会将count的值加 1,从而触发视图的更新。
- 使用
- 生命周期钩子
onMounted:- 使用
onMounted生命周期钩子,在组件挂载到 DOM 后执行一些逻辑。 - 在这里,
console.log('组件已挂载')会在浏览器控制台输出一条消息,表明组件已成功挂载。
- 使用
二、响应式系统
Vue 3 的响应式系统是其核心特性之一,它通过 Proxy 对数据进行代理,从而实现数据的自动追踪和更新。
2.1 响应式工具
1. ref
- 用于创建基本类型的响应式数据。
- 通过
.value访问和修改响应式数据。
import { ref } from 'vue';const count = ref(0);
console.log(count.value); // 输出 0
count.value++;
console.log(count.value); // 输出 1
2. reactive
- 用于创建复杂类型(如对象、数组)的响应式数据。
- 不需要通过
.value访问属性。
import { reactive } from 'vue';const person = reactive({name: 'Alice',age: 25,
});console.log(person.name); // 输出 Alice
person.age++;
console.log(person.age); // 输出 26
3. computed
- 用于创建基于其他响应式数据的计算属性。
- 支持缓存,只有依赖的数据发生变化时才会重新计算。
import { ref, computed } from 'vue';const count = ref(0);
const doubleCount = computed(() => count.value * 2);console.log(doubleCount.value); // 输出 0
count.value++;
console.log(doubleCount.value); // 输出 2
2.2 响应式系统的核心原理
Vue 3 的响应式系统基于 ES6 的 Proxy 实现,主要有以下特点:
- 依赖追踪:当模板或计算属性使用响应式数据时,Vue 会自动追踪数据的依赖。
- 自动更新:当响应式数据发生变化时,Vue 会自动更新依赖该数据的视图。
- 懒加载:计算属性和
watch会在需要时才执行。
2.3 响应式数据的监听
1. 使用 watch
watch 用于监听响应式数据的变化,并执行副作用。
import { ref, watch } from 'vue';const count = ref(0);watch(count, (newVal, oldVal) => {console.log(`count 从 ${oldVal} 变为 ${newVal}`);
});count.value++; // 输出:count 从 0 变为 1
2. 使用 watchEffect
watchEffect 会自动追踪响应式数据的依赖,并在数据变化时重新执行。
import { ref, watchEffect } from 'vue';const count = ref(0);watchEffect(() => {console.log(`count 的值是:${count.value}`);
});count.value++; // 输出:count 的值是:1
三、案例实践:Todo 应用
以下是一个简单的 Todo 应用,使用 Composition API 和 Vue 3 的响应式系统。
功能
- 添加任务。
- 删除任务。
- 显示任务列表。
代码实现
<template><div><h1>Todo 应用</h1><input v-model="newTask" placeholder="输入任务" /><button @click="addTask">添加任务</button><ul><li v-for="(task, index) in tasks" :key="index">{{ task }}<button @click="removeTask(index)">删除</button></li></ul></div>
</template><script>
import { ref } from 'vue';export default {setup() {const newTask = ref('');const tasks = ref([]);const addTask = () => {if (newTask.value.trim()) {tasks.value.push(newTask.value.trim());newTask.value = '';}};const removeTask = (index) => {tasks.value.splice(index, 1);};return {newTask,tasks,addTask,removeTask,};},
};
</script><style>
h1 {font-size: 24px;margin-bottom: 20px;
}
input {padding: 5px;margin-right: 10px;
}
button {padding: 5px 10px;
}
ul {list-style: none;padding: 0;
}
li {margin: 10px 0;display: flex;align-items: center;
}
</style>
代码解析:
- 响应式数据
- 使用
ref创建了两个响应式数据:newTask:绑定到输入框,用于存储用户输入的任务内容。tasks:存储任务列表的数组。
- 添加任务功能
- 方法
addTask:- 检查
newTask是否为空,避免添加空任务。 - 使用
trim()去除多余的空格。 - 如果输入合法,将任务添加到
tasks数组中,并清空输入框。
- 检查
- 删除任务功能
- 方法
removeTask:- 使用
splice方法根据索引删除指定的任务。
- 使用
- 列表渲染
- 使用
v-for遍历tasks数组,将每个任务渲染为一个列表项。 - 使用
:key="index"为每个列表项设置唯一的键,确保 Vue 能正确地追踪列表的变化。
- 双向绑定
-
使用
v-model将输入框的值绑定到newTask,实现双向数据绑定。- 使用
trim()去除多余的空格。 - 如果输入合法,将任务添加到
tasks数组中,并清空输入框。
- 使用
相关文章:
重生之我在学Vue--第2天 Vue 3 Composition API 与响应式系统
重生之我在学Vue–第2天 Vue 3 Composition API 与响应式系统 文章目录 重生之我在学Vue--第2天 Vue 3 Composition API 与响应式系统前言一、Composition API 核心概念1.1 什么是 Composition API?1.2 Composition API 的核心工具1.3 基础用法示例 二、响应式系统2…...
【AI知识】逻辑回归介绍+ 做二分类任务的实例(代码可视化)
1. 分类的基本概念 在机器学习的有监督学习中,分类一种常见任务,它的目标是将输入数据分类到预定的类别中。具体来说: 分类任务的常见应用: 垃圾邮件分类:判断一封电子邮件是否是垃圾邮件 。 医学诊断:…...
Mysql 笔记2 emp dept HRs
-- 注意事项 -- 1.给数据库和表起名字时尽量选择全小写 -- 2.作为筛选条件的字符串是否区分大小写看设置的校对规则utf8_bin 区分 drop database if exists hrs; create database hrs default charset utf8 collate utf8_general_ci;use hrs; drop table if exists tb_emp; dro…...
MySQL和Oracle的区别
MySQL和Oracle的区别 MySQL是轻量型数据库,并且免费,没有服务恢复数据。 Oracle是重量型数据库,收费,Oracle公司对Oracle数据库有任何服务。 1.对事务的提交 MySQL默认是自动提交,而Oracle默认不自动提交࿰…...
实验12 C语言连接和操作MySQL数据库
一、安装MySQL 1、使用包管理器安装MySQL sudo apt update sudo apt install mysql-server2、启动MySQL服务: sudo systemctl start mysql3、检查MySQL服务状态: sudo systemctl status mysql二、安装MySQL开发库 sudo apt-get install libmysqlcli…...
09篇--图片的水印添加(掩膜的运用)
如何添加水印? 添加水印其实可以理解为将一张图片中的某个物体或者图案提取出来,然后叠加到另一张图片上。具体的操作思想是通过将原始图片转换成灰度图,并进行二值化处理,去除背景部分,得到一个类似掩膜的图像。然后…...
sql-labs(21-25)
第21关 第一步 可以发现cookie是经过64位加密的 我们试试在这里注入 选择给他编码 发现可以成功注入 爆出表名 爆出字段 爆出数据 第22关 跟二十一关一模一样 闭合换成" 第 23 关 第二十三关重新回到get请求,会发现输入单引号报错,但是注释符…...
CTF知识集-命令执行
CTF知识集-命令执行 写在开头可能会用到的提醒 ;可以用%0a来替换 是shell_exec的缩写 ls | tee 1 把ls的输出内容存入1这个文件 shell查看文件的几种方式,tac | more | less | tail | sort | tac | cat | head | od | expand 针对flag 可以用grep { flag.php来…...
基于米尔全志T527开发板的OpenCV进行手势识别方案
本文将介绍基于米尔电子MYD-LT527开发板(米尔基于全志T527开发板)的OpenCV手势识别方案测试。 摘自优秀创作者-小火苗 米尔基于全志T527开发板 一、软件环境安装 1.安装OpenCV sudo apt-get install libopencv-dev python3-opencv 2.安装pip sudo apt…...
Htpp中web通讯发送post(上传文件)、get请求
一、正常发送post请求 1、引入pom文件 <dependency><groupId>org.apache.httpcomponents</groupId><artifactId>httpclient</artifactId><version>4.5</version></dependency>2、这个是发送至正常的post、get请求 import org…...
【论文阅读笔记】HunyuanVideo: A Systematic Framework For Large Video Generative Models
HunyuanVideo: A Systematic Framework For Large Video Generative Models 前言引言Overview数据预处理数据过滤数据注释 模型架构设计3D Variational Auto-encoder Designtraininginference 统一的图像和视频生成架构Text encoderModel ScalingImage model scaling lawvideo …...
SpringBoot的事务钩子函数
如果需要在A方法执行完成之后做一个不影响主方法运行的动作B,我们需要判断这个A方法是否存在事务,并且使用异步执行动作B; import org.springframework.transaction.support.TransactionSynchronization; import org.springframework.transa…...
源码安装PHP-7.2.19
源码安装PHP-7.2.19 1.解压 tar -xjvf php-7.2.19.tar.bz2.编译 -prefix安装路径 cd php-7.2.19 ./configure --prefix/home/work/study 成功输出 3.make(构建) makemake testmake installlinux对php操作的一些命令 # 进入到php [rootvdb1 study]# cd php/ [rootvdb1 st…...
UE5制作伤害浮动数字
效果演示: 首先创建一个控件UI 添加画布和文本 文本设置样式 添加伤害浮动动画,根据自己喜好调整,我设置了缩放和不透明度 添加绑定 转到事件图表,事件构造设置动画 创建actor蓝图类 添加widget 获取位置 设置位移 创建一个被击中…...
学习日志024--opencv中处理轮廓的函数
目录 前言 一、 梯度处理的sobel算子函数 功能 参数 返回值 代码演示 二、梯度处理拉普拉斯算子 功能 参数 返回值 代码演示 三、Canny算子 功能 参数 返回值 代码演示 四、findContours函数与drawContours函数 功能 参数 返回值 代码演示 …...
(2024年最新)Linux(Ubuntu) 中配置静态IP(包含解决每次重启后配置文件失效问题)
Hello! 亲爱的小伙伴们,大家好呀(Smile~)!我是Huazzi,欢迎观看本篇博客,接下来让我们一起来学习一下Ubuntu 中如何配置静态IP吧!祝你有所收获! 提前对Linux有所了解的小伙伴应该知道…...
DPDK用户态协议栈-TCP Posix API 2
tcp posix api send发送 ssize_t nsend(int sockfd, const void *buf, size_t len, __attribute__((unused))int flags) {ssize_t length 0;void* hostinfo get_host_fromfd(sockfd);if (hostinfo NULL) {return -1;}struct ln_tcp_stream* stream (struct ln_tcp_stream…...
[IT项目管理]项目时间管理(本章节3w字爆肝)
七.项目时间管理 7.1 项目进度的重要性 为什么要重视项目进度:在项目进行的过程之中会遇到变故。但是不论项目中发生了什么,时间总是在流逝,就可能会导致项目不可以在规定的时间完成。 7.2可能影响项目进度的因素 有员工离职个人的工作方…...
【python因果库实战5】使用银行营销数据集研究营销决策的效果5
目录 接触次数的效应 重新定义治疗变量和潜在混杂因素 更深入地审视干预情景 逆概率加权 标准化 总结及与非因果分析的比较 接触次数的效应 我们现在转而研究当前营销活动中接触次数的数量(campaign)对积极结果发生率的影响。具体来说,…...
【Qt】QWidget中的常见属性及其功能(二)
目录 六、windowOpacity 例子: 七、cursor 例子: 八、font 九、toolTip 例子: 十、focusPolicy 例子: 十一、styleSheet 计算机中的颜色表示 例子: 六、windowOpacity opacity是不透明度的意思。 用于设…...
从WWDC看苹果产品发展的规律
WWDC 是苹果公司一年一度面向全球开发者的盛会,其主题演讲展现了苹果在产品设计、技术路线、用户体验和生态系统构建上的核心理念与演进脉络。我们借助 ChatGPT Deep Research 工具,对过去十年 WWDC 主题演讲内容进行了系统化分析,形成了这份…...
LeetCode - 394. 字符串解码
题目 394. 字符串解码 - 力扣(LeetCode) 思路 使用两个栈:一个存储重复次数,一个存储字符串 遍历输入字符串: 数字处理:遇到数字时,累积计算重复次数左括号处理:保存当前状态&a…...
Keil 中设置 STM32 Flash 和 RAM 地址详解
文章目录 Keil 中设置 STM32 Flash 和 RAM 地址详解一、Flash 和 RAM 配置界面(Target 选项卡)1. IROM1(用于配置 Flash)2. IRAM1(用于配置 RAM)二、链接器设置界面(Linker 选项卡)1. 勾选“Use Memory Layout from Target Dialog”2. 查看链接器参数(如果没有勾选上面…...
AI书签管理工具开发全记录(十九):嵌入资源处理
1.前言 📝 在上一篇文章中,我们完成了书签的导入导出功能。本篇文章我们研究如何处理嵌入资源,方便后续将资源打包到一个可执行文件中。 2.embed介绍 🎯 Go 1.16 引入了革命性的 embed 包,彻底改变了静态资源管理的…...
视频行为标注工具BehaviLabel(源码+使用介绍+Windows.Exe版本)
前言: 最近在做行为检测相关的模型,用的是时空图卷积网络(STGCN),但原有kinetic-400数据集数据质量较低,需要进行细粒度的标注,同时粗略搜了下已有开源工具基本都集中于图像分割这块,…...
推荐 github 项目:GeminiImageApp(图片生成方向,可以做一定的素材)
推荐 github 项目:GeminiImageApp(图片生成方向,可以做一定的素材) 这个项目能干嘛? 使用 gemini 2.0 的 api 和 google 其他的 api 来做衍生处理 简化和优化了文生图和图生图的行为(我的最主要) 并且有一些目标检测和切割(我用不到) 视频和 imagefx 因为没 a…...
处理vxe-table 表尾数据是单独一个接口,表格tableData数据更新后,需要点击两下,表尾才是正确的
修改bug思路: 分别把 tabledata 和 表尾相关数据 console.log() 发现 更新数据先后顺序不对 settimeout延迟查询表格接口 ——测试可行 升级↑:async await 等接口返回后再开始下一个接口查询 ________________________________________________________…...
Go 并发编程基础:通道(Channel)的使用
在 Go 中,Channel 是 Goroutine 之间通信的核心机制。它提供了一个线程安全的通信方式,用于在多个 Goroutine 之间传递数据,从而实现高效的并发编程。 本章将介绍 Channel 的基本概念、用法、缓冲、关闭机制以及 select 的使用。 一、Channel…...
JS手写代码篇----使用Promise封装AJAX请求
15、使用Promise封装AJAX请求 promise就有reject和resolve了,就不必写成功和失败的回调函数了 const BASEURL ./手写ajax/test.jsonfunction promiseAjax() {return new Promise((resolve, reject) > {const xhr new XMLHttpRequest();xhr.open("get&quo…...
从 GreenPlum 到镜舟数据库:杭银消费金融湖仓一体转型实践
作者:吴岐诗,杭银消费金融大数据应用开发工程师 本文整理自杭银消费金融大数据应用开发工程师在StarRocks Summit Asia 2024的分享 引言:融合数据湖与数仓的创新之路 在数字金融时代,数据已成为金融机构的核心竞争力。杭银消费金…...
