vue3基本类型和对象类型的响应式数据
vue3中基本类型和对象类型的响应式数据
OptionsAPI与CompstitionAPI的区别
OptionsAPI
Options API
• 特点:基于选项(options)来组织代码,将逻辑按照生命周期、数据、方法等分类。• 结构:代码按照 data 、 methods 、 computed 、 watch 等选项分块。
<template><div class="person"><h2>姓名:{{name}}</h2><h2>年龄:{{age}}</h2><button @click="updataName">修改姓名</button><button @click="updataAge">修改年龄</button><button @click="showTel">查看联系方式</button></div>
</template><script lang="ts">export default{name:'Person',data(){return{name:'小聂',age:18,tel:'1598744444'}},methods:{updataName(){this.name='xiao-nie'},updataAge(){this.age+=1},showTel(){alert(this.tel)}}}
</script><style>.person{background-color: rebeccapurple;box-shadow: 0 0 10px;padding: 20px;border-radius: 10px;}button{margin: 0 6px;}
</style>
点击之后页面进行了修改
CompstitionAPI
Composition API
• 特点:基于函数组合(composition)来组织代码,将逻辑按照功能模块划分。
• 结构:代码通过 setup 函数组织,使用 ref 、 reactive 、 computed 、 watch 等函数来定义响应式数据和逻辑。
<template><div class="person"><h2>姓名:{{name}}</h2><h2>年龄:{{age}}</h2><button @click="updataName">修改姓名</button><button @click="updataAge">修改年龄</button><button @click="showTel">查看联系方式</button></div>
</template><script lang="ts">export default{name:'Person',setup(){let name="小聂" //此时的name不是响应式的let age=18 //此时的age不是响应式的let tel='188844444' //此时的tel不是响应式的function updataName(){name="xiao-nie"}function updataAge(){age+=1}function showTel(){alert(tel)}return {name,age,tel,updataName,updataAge,showTel};}}
</script><style>.person{background-color: rebeccapurple;box-shadow: 0 0 10px;padding: 20px;border-radius: 10px;}button{margin: 0 6px;}
</style>
因为不是响应式的基本类型 所以点击之后页面并没有反应
OptionsAPI和CompositionAPI的优缺点
OptionsAPI优点
:
- 易学易用:对于初学者来说,Options API 的结构非常直观,代码组织方式类似于 Vue 2,学习曲线平缓。
- 易于理解:代码按照生命周期、数据、方法等选项分块,逻辑清晰,易于阅读和维护。
OptionsAPI缺点
:
2. 复用性差
- 混入(Mixins)问题:虽然可以通过混入复用逻辑,但混入可能导致命名冲突,且逻辑分散在多个地方,难以追踪。
- 组件继承问题:通过组件继承复用逻辑时,子组件可能会继承过多不必要的逻辑,导致代码臃肿。
- 复杂组件难以管理
- 逻辑分散:对于复杂组件,逻辑可能会分散在多个选项中(如 data 、 methods 、 computed 等),难以集中管理。
- 维护困难:随着组件逻辑的增加,代码的可读性和可维护性会下降。
CompositionAPI优点
:
- 高度复用性
组合函数(Composables):通过组合函数可以将逻辑模块化,便于复用和组合。逻辑清晰,避免了混入带来的命名冲突。
逻辑集中:将相关逻辑集中在一个函数中,便于管理和维护。 - 适合复杂组件
灵活的代码组织:可以将逻辑按照功能模块划分,适合复杂组件的开发。
可读性强:通过 setup 函数组织代码,逻辑更加清晰,易于理解和维护。
强大的类型支持 - TypeScript 友好:在 TypeScript 中,Composition API 提供了强大的类型推断,减少了手动声明类型的工作量,提高了开发效率。
CompositionAPI缺点
:
- 学习曲线较陡
语法复杂:对于初学者来说,Composition API 的语法和概念(如 ref 、 reactive 等)可能需要一些时间来适应。
文档和资源较少:虽然 Vue 3 的文档已经很完善,但相比 Options API,Composition API 的学习资源和社区支持相对较少。
setup返回值
<template><div class="person"><h2>姓名:{{name}}</h2><h2>年龄:{{age}}</h2><button @click="updataName">修改姓名</button><button @click="updataAge">修改年龄</button><button @click="showTel">查看联系方式</button></div>
</template><script lang="ts">export default{name:'Person',setup(){let name="小聂" //此时的name不是响应式的let age=18 //此时的age不是响应式的let tel='188844444' //此时的tel不是响应式的function updataName(){name="xiao-nie"}function updataAge(){age+=1}function showTel(){alert(tel)}return ()=>"接着努力啊! 小聂!"}}
</script><style>.person{background-color: rebeccapurple;box-shadow: 0 0 10px;padding: 20px;border-radius: 10px;}button{margin: 0 6px;}
</style>
setup和OptionsAPI的关系
setup里面不可以调用data里面的数据 但是data可以调用setup里面的数据
<template><div class="person"><h2>姓名:{{name}}</h2><h2>年龄:{{age}}</h2><button @click="updataName">修改姓名</button><button @click="updataAge">修改年龄</button><button @click="showTel">查看联系方式</button><br><h2>data访问setup里的name为:{{a}}</h2><button @click="updataA">查看name</button></div>
</template><script lang="ts">export default{name:'Person',data(){return {a:this.name}},methods:{updataA(){console.log(this.a)}},setup(){let name="小聂" //此时的name不是响应式的let age=18 //此时的age不是响应式的let tel='188844444' //此时的tel不是响应式的function updataName(){name="xiao-nie"}function updataAge(){age+=1}function showTel(){alert(tel)}return {name,age,tel,updataName,updataAge,showTel};}}
</script><style>.person{background-color: rebeccapurple;box-shadow: 0 0 10px;padding: 20px;border-radius: 10px;}button{margin: 0 6px;}
</style>
<template><div class="person"><h2>姓名:{{name}}</h2><h2>年龄:{{age}}</h2><button @click="updataName">修改姓名</button><button @click="updataAge">修改年龄</button><button @click="showTel">查看联系方式</button></div>
</template><script lang="ts">export default {name:'Person',}
</script><script lang="ts" setup>let name="小聂" //此时的name不是响应式的let age=18 //此时的age不是响应式的let tel='188844444' //此时的tel不是响应式的function updataName(){name="xiao-nie"}function updataAge(){age+=1}function showTel(){alert(tel)}
</script><style>.person{background-color: rebeccapurple;box-shadow: 0 0 10px;padding: 20px;border-radius: 10px;}button{margin: 0 6px;}
</style>
小提示 如果像上面这样写我们需要在加入一个script
所以我们我们可以借助vite
中的插件简化
下载插件 npm i vite-plugin-vue-setup-extend -D
更改vite.config.ts
import { fileURLToPath, URL } from 'node:url'import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import vueDevTools from 'vite-plugin-vue-devtools'
import VueSetupExtend from 'vite-plugin-vue-setup-extend'// https://vite.dev/config/
export default defineConfig({plugins: [vue(),vueDevTools(),[ VueSetupExtend() ]],resolve: {alias: {'@': fileURLToPath(new URL('./src', import.meta.url))},},
})
ref 创建:基本类型的响应式数据
<template><div class="person"><h2>姓名:{{name}}</h2><h2>年龄:{{age}}</h2><button @click="updataName">修改姓名</button><button @click="updataAge">修改年龄</button><button @click="showTel">查看联系方式</button></div>
</template><script lang="ts" setup name="Person">import {ref} from 'vue'let name=ref("小聂" )let age=ref(18) let tel='188844444' function updataName(){name.value="xiao-nie"}function updataAge(){age.value+=1}function showTel(){alert(tel)}
</script><style>.person{background-color: rebeccapurple;box-shadow: 0 0 10px;padding: 20px;border-radius: 10px;}button{margin: 0 6px;}
</style>
我们想让谁变成响应式的 我们就把他用ref包裹起来 这样他就变成了响应式的了
点击之后页面变了
reactive创建:对象类型的响应式数据
<template><div class="person"><h2>有一部{{phone.name}}手机,价格为{{ phone.price }}</h2><button @click="changeName">修改名称</button><button @click="changePrice">修改价格</button></div>
</template><script lang="ts" setup name="Person">import {reactive} from 'vue'let phone=reactive({name:'小米',price:3000})function changeName(){phone.name="苹果"}function changePrice(){phone.price+=1000}</script><style>.person{background-color: rebeccapurple;box-shadow: 0 0 10px;padding: 20px;border-radius: 10px;}button{margin: 0 6px;}
</style>
点击修改名称和修改价格后
当我们要进行整体替换的时候我们需要用到Object
ref创建:对象类型的响应式数据
<template><div class="person"><ul><li v-for="g in games" :key="g.id">{{ g.name }}</li></ul><button @click="changeFirst">修改第一个游戏的名称</button><button @click="changeTwo">修改第二个游戏的名称</button></div>
</template><script lang="ts" setup name="Person">import {ref} from 'vue'let games=ref([{id:"1",name:"英雄联盟"},{id:"2",name:"CSGO"},{id:"3",name:"无畏契约"}])function changeFirst(){games.value[0].name='王者荣耀'}function changeTwo(){games.value[2].name='金铲铲之战'}</script><style>.person{background-color: rebeccapurple;box-shadow: 0 0 10px;padding: 20px;border-radius: 10px;}button{margin: 0 6px;}
</style>
点击修改后 我们可以看到 页面发生了改变
ref 对比 reactive
ref :既可以用来定义基本类型数据 又可以用来定义对象型类型数据
reactive:只可以用来定义对象数据
ref 创建的变量需要进行修改的时候 必须使用.value
<template><div class="person"><h2>有一部{{phone.name}}手机,价格为{{ phone.price }}</h2><button @click="changeName">修改名称</button><button @click="changePrice">修改价格</button><button @click="changePhone">修改手机</button></div>
</template><script lang="ts" setup name="Person">import {ref} from 'vue'let phone=ref({name:'小米',price:3000})function changeName(){phone.value.name="苹果"}function changePrice(){phone.value.price+=1000}function changePhone(){phone.value={name:"苹果",price:6000}}</script><style>.person{background-color: rebeccapurple;box-shadow: 0 0 10px;padding: 20px;border-radius: 10px;}button{margin: 0 6px;}
</style>
在ref中 直接修改即可
当我们点击修改手机时 页面发生了改变
reactive重新分配一个新的对象的时候 会失去响应式 我们可以使用Object.assign去整体替换
<template><div class="person"><h2>有一部{{phone.name}}手机,价格为{{ phone.price }}</h2><button @click="changeName">修改名称</button><button @click="changePrice">修改价格</button><button @click="changePhone">修改手机</button></div>
</template><script lang="ts" setup name="Person">import {reactive} from 'vue'let phone=reactive({name:'小米',price:3000})function changeName(){phone.name="苹果"}function changePrice(){phone.price+=1000}function changePhone(){Object.assign(phone,{name:"苹果",price:"6000"})}</script><style>.person{background-color: rebeccapurple;box-shadow: 0 0 10px;padding: 20px;border-radius: 10px;}button{margin: 0 6px;}
</style>
点击修改手机后 页面发生了改变
相关文章:

vue3基本类型和对象类型的响应式数据
vue3中基本类型和对象类型的响应式数据 OptionsAPI与CompstitionAPI的区别 OptionsAPI Options API • 特点:基于选项(options)来组织代码,将逻辑按照生命周期、数据、方法等分类。• 结构:代码按照 data 、 methods…...

3.8.4 利用RDD实现分组排行榜
本实战任务通过Spark RDD实现学生成绩的分组排行榜。首先,准备包含学生成绩的原始数据文件,并将其上传至HDFS。接着,利用Spark的交互式环境或通过创建Maven项目的方式,读取HDFS中的成绩文件生成RDD。通过map操作将数据映射为二元组…...

python web flask专题-Flask入门指南:从安装到核心功能详解
Flask入门指南:从安装到核心功能详解 Flask作为Python最流行的轻量级Web框架之一,以其简洁灵活的特性广受开发者喜爱。本文将带你从零开始学习Flask,涵盖安装配置、项目结构、应用实例、路由系统以及请求响应处理等核心知识点。 1. Flask安…...
C语言中的“类框架”工具
C语言中的“框架”:库与轻量级工具生态解析 一、C语言的设计哲学与框架定位 C语言作为一门系统级编程语言,核心目标是提供高效、灵活的底层控制能力。与Java、Python等高级语言不同,C语言本身不内置全栈框架…...

【HW系列】—web组件漏洞(Strtus2和Apache Log4j2)
本文仅用于技术研究,禁止用于非法用途。 文章目录 Struts2Struts2 框架介绍Struts2 历史漏洞汇总(表格)Struts2-045 漏洞详解 Log4j2Log4j2 框架介绍Log4j2 漏洞原理1. JNDI 注入2. 利用过程 Log4j2 历史漏洞JNDILDAP 反弹 Shell 流程 Strut…...
第六十八篇 从“超市收银系统崩溃”看JVM性能监控与故障定位实战
目录 引言:当技术问题遇上生活场景一、JVM的“超市货架管理哲学”二、收银员工具箱:JVM监控三板斧三、典型故障诊断实录四、防患于未然的运维智慧五、结语:从故障救火到体系化防控 引言:当技术问题遇上生活场景 想象一个周末的傍…...
Debian 11 之使用hostapd与dnsmasq进行AP设置
目录 1: 安装必要的软件2: 配置dnsmasq3: 配置 hostapd4: 配置网络接口5: 启动服务总结 在Debian 11(也称为Bullseye)下设置热点,你可以使用多种方法,但最常见和简单的方法之一是使用hostapd工具配合dnsmasq。这种方法不需要额外的…...
有铜半孔的设计规范与材料创新
设计关键参数 孔径与间距限制 最小孔径需≥0.6mm,孔边距≥0.5mm,避免铜层脱落;拼版时半孔区域需预留2mm间距防止撕裂。 阻焊桥设计 必须保留阻焊桥(宽度≥0.1mm),防止焊锡流入孔内造成短路。 猎板的材料…...

机器学习知识体系:从“找规律”到“做决策”的全过程解析
你可能听说过“机器学习”,觉得它很神秘,像是让电脑自己学会做事。其实,机器学习的本质很简单:通过数据来自动建立规则,从而完成预测或决策任务。 这篇文章将用通俗的语言为你梳理机器学习的知识体系,帮助…...

STM32之FreeRTOS移植(重点)
RTOS的基本概念 实时操作系统(Real Time Operating System)的简称就叫做RTOS,是指具有实时性、能支持实时控制系统工作的操作系统,RTOS的首要任务就是调度所有可以利用的资源来完成实时控制任务的工作,其次才是提高工…...
做好测试用例设计工作的关键是什么?
测试用例设计是软件测试的核心环节,好的测试用例能高效发现缺陷,差的测试用例则可能漏测关键问题。结合多年测试经验,我认为做好测试用例设计的关键在于以下6点: 1. 深入理解需求(核心基础) ✅ 关键点: 与产品经理/开发对齐,确保理解无偏差(避免“我以为”式测试) 拆…...

R语言科研编程-标准偏差柱状图
生成随机数据 在R中,可以使用rnorm()生成正态分布的随机数据,并模拟分组数据。以下代码生成3组(A、B、C)随机数据,每组包含10个样本: set.seed(123) # 确保可重复性 group_A <- rnorm(10, mean50, sd…...
未来教育考试答题软件4.0【自用链接备份】
未来教育考试答题软件4.0【自用链接备份】 http://www.downyi.com/downinfo/240413.html 补丁地址:https://www.wodown.com/soft/43108.html...

OpenGL Chan视频学习-11 Uniforms in OpenGL
bilibili视频链接: 【最好的OpenGL教程之一】https://www.bilibili.com/video/BV1MJ411u7Bc?p5&vd_source44b77bde056381262ee55e448b9b1973 函数网站: docs.gl 说明: 1.之后就不再单独整理网站具体函数了,网站直接翻译…...
Flink系列文章列表
把写的文章做一个汇总,会陆续更新的。 Flink流处理原理与实践:状态管理、窗口操作与容错机制-CSDN博客...

GitLab 从 17.10 到 18.0.1 的升级指南
本文分享从 GitLab 中文本 17.10.0 升级到 18.0.1 的完整过程。 升级前提 查看当前安装实例的版本。有多种方式可以查看: 方式一: /help页面 可以直接在 /help页面查看当前实例的版本。以极狐GitLab SaaS 为例,在浏览器中输入 https://ji…...

产业集群间的专利合作关系
需要准备的文件: 全国的专利表目标集群间的企业名单 根据专利的共同申请人,判断这两家企业之间存在专利合作关系。 利用1_filter_patent.py,从全国的3000多万条专利信息中,筛选出与目标集群企业相关的专利。 只要专利的申请人包…...
PyQt学习系列02-模型-视图架构与数据管理
PyQt学习系列笔记(Python Qt框架) 第二课:PyQt的模型-视图架构与数据管理 一、模型-视图架构概述 1.1 什么是模型-视图架构? 模型-视图(Model-View)是Qt框架中用于数据展示和交互的核心设计模式。它将数…...
redis主从复制架构安装与部署
redis主从复制架构安装与部署 1、Redis 一主两从架构的优势2、环境准备3、下载redis4、解压缩文件5、编辑配置文件6、创建数据目录并启动Redis7、检查主从状态8、 Redis Sentinel 模式 1、Redis 一主两从架构的优势 Redis 采用一主两从(1个主节点 2个从节点&#…...
Kotlin 中 Lambda 表达式的语法结构及简化推导
在 Kotlin 编程中,Lambda 表达式是一项非常实用且强大的功能。今天,我们就来深入探讨一下 Lambda 表达式的语法结构,以及它那些令人 “又爱又恨” 的简化写法。 一、Lambda 表达式完整语法结构 Lambda 表达式最完整的语法结构定义为{参数名…...
YOLOv2 深度解析:目标检测领域的进阶之路
在计算机视觉领域,目标检测一直是研究和应用的热点方向。YOLO(You Only Look Once)系列算法以其快速高效的特点,在目标检测领域占据了重要地位。YOLOv2 作为 YOLO 系列算法的重要迭代版本,在 YOLOv1 的基础上进行了诸多…...

KT6368A通过蓝牙芯片获取手机时间详细说明,对应串口指令举例
一、功能简介 KT6368A双模蓝牙芯片支持连接手机,获取手机的日期、时间信息,可以同步RTC时钟 1、无需安装任何app,直接使用系统蓝牙即可实现 2、同时它不影响音频蓝牙,还支持一些简单的AT指令进行操作 3、实现的方式࿱…...

计算机网络实验课(二)——抓取网络数据包,并实现根据条件过滤抓取的以太网帧,分析帧结构
文章目录 一、添加控件二、代码分析2.1 代码2.2 控件初始化2.3 打开和关闭设备2.4 开始和结束捕获2.5 设置捕获条件2.6 捕获数据包 三、运行程序四、结果分析 提要:如果你通过vs打开.sln文件,然后代码界面或者前端界面都没找到,视图里面也没找…...
自动生成提示技术突破:AUTOPROMPT重塑语言模型应用
AUTOPROMPT 预训练语言模型的显著成功促使人们研究这些模型在预训练期间学习了哪些类型的知识。将任务重新表述为填空题(例如,完形填空测试)是衡量此类知识的自然方法 但是,它的使用受到编写合适提示所需的手动工作和猜测的限制。为了解决这个问题,我们开发了 AUTOPROMP…...

78. Subsets和90. Subsets II
目录 78.子集 方法一、迭代法实现子集枚举 方法二、递归法实现子集枚举 方法三、根据子集元素个数分情况收集 方法四、直接回溯法 90.子集二 方法一、迭代法实现子集枚举 方法二、递归法实现子集枚举 方法三、根据子集元素个数分情况收集 方法四、直接回溯法 78.子集…...
VSCode 插件 GitLens 破解方法
文章目录 1. 安装指定版本2. 修改插件文件3. 重启 VSCode 1. 安装指定版本 在 VSCode 中打开扩展(Ctrl Shift X),搜索 GitLens,右键点击 安装特定版本,在弹出的窗口中选择 17.0.2,然后等待安装完成。 2…...
linux 通过命令将 MinIO 桶的权限设置为 Custom(自定义策略)
在 Ubuntu 下,如果要通过命令将 MinIO 桶的权限设置为 Custom(自定义策略),可以使用 mc(MinIO Client)、AWS CLI 或直接调用 MinIO API(如 curl)。以下是几种方法: 方法 …...
模型评价指标介绍
模型评价指标介绍 **在机器学习与数据科学领域,构建模型仅是工作的一部分,更为关键的是要精准评估模型的性能。模型评价指标作为衡量模型表现的标准,有助于数据科学家、分析师等从业者判断模型的优劣,进而进行优化与改进。不同类…...

ElasticSearch整合SpringBoot
ElasticSearch 整合SpringBoot ES官方提供了各种不同语言的客户端。用来操作ES。这些客户端的本质就是组装DSL语句,通过HTTP请求发送给ES。 设计索引库 跟据数据库的表结构进行ES索引库的创建时。如果字段需要进行倒排索引的时候请为它指定分词器。如果该字段不是…...
ArcGIS Pro 3.4 二次开发 - 知识图谱
环境:ArcGIS Pro SDK 3.4 + .NET 8 文章目录 知识图谱1 知识图谱数据存储1.1 打开与知识图谱的连接1.2 从KnowledgeGraphLayer获取连接1.3 检索GDB要素类和定义1.4 检索GDB表和定义1.5 从知识图谱数据存储中获取服务 Uri1.6 将一组对象ID转换为实体的ID1.7 将一组ID转换为实体…...