Vue 中的 ref 与 reactive:让你的应用更具响应性(上)

news2024/11/14 18:47:26

在这里插入图片描述

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6
🍨 阿珊和她的猫_CSDN个人主页
🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》
🍚 蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》

文章目录

  • 一、引言
    • 介绍 ref 与 reactive 的背景和重要性
  • 二、 ref 的基本概念
    • 解释 ref 的定义和作用
    • 展示如何创建和使用 ref
    • 讨论 ref 的一些常见用例
  • 三、 reactive 的基本概念
    • 解释 reactive 的定义和作用
    • 展示如何创建和使用 reactive 对象
    • 讨论 reactive 的一些常见用例

一、引言

介绍 ref 与 reactive 的背景和重要性

refreactive 是 Vue 3 中引入的新特性,它们的背景和重要性如下:

  1. ref 的背景和重要性:
  • 在 Vue 2 中,通过使用 v-bindv-on 等指令来实现数据的双向绑定。但是,在某些情况下,需要直接操作 DOM 元素或组件实例,这时候就需要使用 ref 属性。
  • ref 允许你通过引用的方式访问 DOM 元素或组件实例,从而方便地进行直接操作。在 Vue 3 中,ref 有了一些改进,它现在可以引用任何类型的值,包括组件实例、函数、对象等。
  1. reactive 的背景和重要性:
  • 在 Vue 2 中,响应式系统是基于对象的属性监听实现的。当一个对象的属性发生变化时,Vue 会自动触发更新。
  • 然而,在某些情况下,需要对一个基本数据类型的值进行响应式处理,这时候就需要使用 reactive 方法。
  • reactive 方法可以将一个基本数据类型的值转换为响应式对象,从而使其能够参与到 Vue 的响应式系统中。

总的来说,refreactive 都是 Vue 3 中重要的新特性,它们提供了更强大和灵活的方式来处理 DOM 元素和数据,从而提高了开发效率和代码质量。

二、 ref 的基本概念

解释 ref 的定义和作用

在 Vue 3 中,ref 用于引用 DOM 元素或组件实例。它允许你通过引用的方式直接访问和操作 DOM 元素或组件实例。

ref 的定义如下:

const ref = Vue.createRef()

const ref = useRef()

其中,Vue.createRef() 是 Vue 实例方法,用于创建一个引用对象;useRef() 是Composition API 中的一个函数,也用于创建引用对象。

ref 的作用有以下几个方面:

  1. 获取 DOM 元素:通过 ref,你可以获取对应的 DOM 元素,并进行直接操作,如修改元素的属性、调用元素的方法等。
  2. 引用组件实例:除了 DOM 元素,你还可以使用 ref 来引用组件实例,从而直接访问和操作组件的属性和方法。
  3. 传递引用:通过将 ref 传递给其他组件或函数,你可以在其他地方访问和操作对应的 DOM 元素或组件实例。

需要注意的是,使用 ref 时要遵循一些最佳实践,如避免在多个地方使用同一个 ref 来引用同一个元素或组件实例,以免引发意外行为。此外,在组件中使用 ref 时,要确保组件的生命周期方法(如 createdmounted 等)已经执行完毕,以确保引用的元素或组件实例已经准备好。

展示如何创建和使用 ref

在 Vue 3 中,创建和使用 ref 的方法与 Vue 2 类似,但有一些细微的差别。下面是一个简单的示例,展示了如何在 Vue 3 中创建和使用 ref

  1. 首先,在 Vue 3 中,你需要使用 defineComponent 方法来定义一个组件,例如:
import { defineComponent } from 'vue';

export default defineComponent({
 name: 'MyComponent',
 setup() {
   // 在这里编写组件的逻辑
 },
});
  1. 接下来,你可以使用 ref 方法来创建一个引用,例如:
import { ref } from 'vue';

export default defineComponent({
 name: 'MyComponent',
 setup() {
   const count = ref(0);

   // 你可以使用这个引用,例如:
   return {
     count,
   };
 },
});

在这个示例中,我们创建了一个名为 count 的引用,并将其初始值设置为 0。然后,我们将这个引用返回给组件,以便在模板中使用它。

  1. 在模板中,你可以使用 v-bind 指令将引用绑定到 DOM 元素,例如:
<template>
 <div>
   <p>Count: {{ count }}</p>
   <button v-bind="count">Increment</button>
 </div>
</template>

在这个示例中,我们将 count 引用绑定到 <p> 元素和一个按钮上。当用户点击按钮时,count 的值会增加。

  1. 最后,你可以使用 ref 引用来操作组件或元素的属性,例如:
import { ref } from 'vue';

export default defineComponent({
 name: 'MyComponent',
 setup() {
   const count = ref(0);

   function increment() {
     count.value++;
   }

   return {
     count,
     increment,
   };
 },
});

在这个示例中,我们定义了一个名为 increment 的函数,用于增加 count 的值。然后,我们将这个函数返回给组件,以便在模板中使用它。

总的来说,在 Vue 3 中使用 ref 方法非常简单,你可以使用它来获取对组件或元素的引用,操作组件或元素,并避免直接修改属性。

讨论 ref 的一些常见用例

ref 在 Vue 3 中是一个非常有用的特性,它提供了一种方便的方式来引用 DOM 元素或组件实例。以下是一些常见的用例:

  1. 获取 DOM 元素:通过使用 ref,你可以获取到特定的 DOM 元素,并直接操作它的属性、方法或监听其事件。这对于执行一些与 DOM 相关的操作非常方便。例如:
// 创建一个 ref 来引用元素
const myElement = ref(null);

// 在模板中使用 ref
<template>
  <div ref="myElement"></div>
</template>

// 获取引用的 DOM 元素
const element = myElement.value;
  1. 引用组件实例:除了引用 DOM 元素,你还可以使用 ref 来引用组件实例。这使得你能够直接访问和操作组件的属性和方法。例如:
// 创建一个 ref 来引用组件实例
const myComponent = ref(null);

// 在模板中使用 ref
<template>
  <MyComponent ref="myComponent"></MyComponent>
</template>

// 获取引用的组件实例
const component = myComponent.value;
  1. 传递引用:通过将 ref 传递给其他组件或函数,你可以在不同的地方共享对同一个 DOM 元素或组件实例的引用。这有助于在组件之间进行通信和协同工作。例如:
// 创建一个 ref
const myElement = ref(null);

// 将 ref 传递给子组件
<ChildComponent :element="myElement" />

// 在子组件中使用传递的 ref
const { element } = props;
  1. 处理生命周期事件:你可以使用 ref 来监听 DOM 元素或组件实例的生命周期事件。通过在 ref 的回调函数中处理这些事件,可以在特定的生命周期阶段执行相应的操作。例如:
// 创建一个 ref 来引用元素
const myElement = ref(null);

// 监听 ref 对应的元素的 click 事件
myElement.value.addEventListener('click', handleClickEvent);

// 处理点击事件的函数
function handleClickEvent() {
  console.log('点击事件触发');
}

总之,ref 提供了一种方便的方式来引用和操作 DOM 元素、组件实例,并在组件之间传递引用。它在一些常见的场景中非常有用,例如与 DOM 交互、处理组件通信和监听生命周期事件等。

三、 reactive 的基本概念

解释 reactive 的定义和作用

在 Vue 3 中,reactive 是一个用于创建响应式数据的函数。它将一个普通的对象转换为响应式对象,使其能够与 Vue 的响应式系统进行集成。

reactive 的定义如下:

import { reactive } from 'vue'
const myObject = reactive({ data: 123 })

reactive 的作用是使对象的属性具有响应性。当你修改响应式对象的属性时,Vue 会自动检测到变化,并触发相应的更新。这使得在 Vue 组件中使用响应式数据变得更加方便和高效。

通过使用 reactive 创建响应式对象,你可以将复杂的数据结构(如对象、数组等)与 Vue 的模板进行双向绑定,实现数据的实时更新和视图的自动渲染。

需要注意的是,reactive 只对对象的属性修改进行响应,而不对对象的整体替换进行响应。如果你需要对整个对象进行替换,可以使用 Vue.setvm.$set 方法。

展示如何创建和使用 reactive 对象

在 Vue 3 中,你可以使用 reactive 方法来创建一个响应式对象,以便在组件或元素中使用。下面是一个简单的示例,展示了如何在 Vue 3 中创建和使用 reactive 对象。

  1. 首先,在 Vue 3 中,你需要使用 defineComponent 方法来定义一个组件,例如:
import { defineComponent } from 'vue';

export default defineComponent({
name: 'MyComponent',
setup() {
  // 在这里编写组件的逻辑
},
});
  1. 接下来,你可以使用 reactive 方法来创建一个响应式对象,例如:
import { reactive } from 'vue';

export default defineComponent({
name: 'MyComponent',
setup() {
  const state = reactive({
    count: 0,
    message: 'Hello, Vue 3!',
  });

  // 你可以使用这个对象,例如:
  return {
    state,
  };
},
});

在这个示例中,我们使用 reactive 方法创建了一个名为 state 的响应式对象,并将其初始值设置为 { count: 0, message: 'Hello, Vue 3!' }。然后,我们将这个对象返回给组件,以便在模板中使用它。

  1. 在模板中,你可以使用 v-bind 指令将响应式对象绑定到 DOM 元素,例如:
<template>
<div>
  <p>Count: {{ state.count }}</p>
  <p>Message: {{ state.message }}</p>
  <button v-bind="state">Increment</button>
</div>
</template>

在这个示例中,我们将 state 对象绑定到 <p> 元素和一个按钮上。当用户点击按钮时,state 对象的 count 属性会增加,而 message 属性不会改变。

  1. 最后,你可以使用 reactive 对象的属性来操作对象,例如:
import { reactive } from 'vue';

export default defineComponent({
name: 'MyComponent',
setup() {
  const state = reactive({
    count: 0,
    message: 'Hello, Vue 3!',
  });

  function increment() {
    state.count++;
  }

  return {
    state,
    increment,
  };
},
});

在这个示例中,我们定义了一个名为 increment 的函数,用于增加 state 对象的 count 属性。然后,我们将这个函数返回给组件,以便在模板中使用它。

总的来说,在 Vue 3 中使用 reactive 方法非常简单,你可以使用它来创建一个响应式对象,以便在组件或元素中使用。

讨论 reactive 的一些常见用例

reactive 在 Vue 3 中是一个非常重要的特性,它提供了一种创建响应式数据的简洁方式。以下是一些常见的用例:

  1. 创建响应式对象:使用 reactive 可以将一个普通对象转换为响应式对象。当响应式对象的属性发生变化时,相关的组件会自动更新。这对于处理复杂的数据结构非常有用。例如:
// 创建一个响应式对象
const myObject = reactive({ data: 123 });

// 修改对象的属性
myObject.data += 1;

console.log(myObject.data); 
  1. 创建响应式数组:reactive 也可以用于创建响应式数组。响应式数组的元素变更时,相关的组件也会自动更新。例如:
// 创建一个响应式数组
const myArray = reactive([1, 2, 3]);

// 修改数组的元素
myArray.push(4);

console.log(myArray); 
  1. 与 Computed 属性结合使用:通过将 reactive 对象与计算属性(Computed Properties)结合使用,可以创建基于响应式数据的动态计算。例如:
// 创建一个响应式对象
const myObject = reactive({ data: 123 });

// 创建一个计算属性
const computedData = computed(() => myObject.data * 2);

console.log(computedData); 
  1. 在组件之间传递响应式数据:通过使用 reactive 创建响应式数据,可以在组件之间传递数据,并且当数据发生变化时,相关的组件会自动更新。这有助于保持组件之间的数据一致性。例如:
// 创建一个响应式对象
const myObject = reactive({ data: 123 });

// 在子组件中使用响应式数据
<ChildComponent :data="myObject.data" />

总之,reactive 提供了一种简单而高效的方式来创建响应式数据,使你的 Vue 应用更加动态和灵活。

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

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

相关文章

uniapp中uview组件库丰富LoadingPage 加载页

目录 基本使用 #显示或隐藏 #文字内容 #动画模式 #动画图片 #文字颜色 #文字大小 #图标大小 2.0.32 #背景颜色 #图标颜色 API #Props 基本使用 <template><view><u-loading-page></u-loading-page></view> </template>#显示或…

Flink版本更新汇总(1.14-1.18)

0、汇总 1.14.0 1.有界流支持 Checkpoint&#xff1b; 2.批执行模式支持 DataStream 和 Table/SQL 混合应用&#xff1b; 3.新增 Hybrid Source 功能&#xff1b; 4.新增 缓冲区去膨胀 功能&#xff1b; 5.新增 细粒度资源管理 功能&#xff1b; 6.新增 DataStream 的 Pulsar …

.mallox勒索病毒数据恢复|金蝶、用友、管家婆、OA、速达、ERP等软件数据库恢复

引言&#xff1a; 随着技术的不断发展&#xff0c;网络空间也不可避免地面临着各种威胁&#xff0c;其中之一就是勒索病毒&#xff0c;而.mallox是近期引起关注的一种恶意软件。本文将介绍.mallox勒索病毒&#xff0c;以及如何有效地恢复被其加密的数据文件&#xff0c;并提供…

高德地图经纬度坐标导出工具

https://tool.xuexiareas.com/map/amap 可以导出单个点&#xff0c;也可以导出多个&#xff0c;多个点可以连成线&#xff0c;可用于前端开发时自己模拟“线“数据

修复键盘问题的十种方法,总有一种可以帮到你

坏了的键盘可不是闹着玩的。这就是为什么苹果公司向人们支付395美元,以解决其蝴蝶键盘故障的集体诉讼。但这个问题并不总是那么普遍,所以这通常意味着如果出现问题,你只能靠自己了。 重新启动电脑 你有没有试过反复打开电脑?在你尝试任何随机修复之前,一个简单的重新启动…

基于SSM的滁艺咖啡在线销售系统设计与实现

末尾获取源码 开发语言&#xff1a;Java Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;SSM 前端&#xff1a;Vue 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xff1a;IDEA / Eclipse 是否Maven项目&#xff1a;是 目录…

【致远OA】获取指定人员的协同待发列表

接口请求说明 V6.0接口更新:不在传入ticket&#xff0c;改为传memberId人员ID V6.0之前http请求方式&#xff1a;GET http://ip:port/seeyon/rest/affairs/draft 如 http://127.0.0.1/seeyon/rest/affairs/draft?ticketxxxxxx V6.0http请求方式&#xff1a;GET http://ip:p…

Grafana UI 入门使用

最近项目上需要使用Grafana来做chart&#xff0c;因为server不是我在搭建&#xff0c;所以就不介绍怎么搭建grafana server&#xff0c;而是谈下怎么在UI上具体操作使用了。 DOCs 首先呢&#xff0c;贴一下官网doc的连接&#xff0c;方便查询 Grafana open source documenta…

记一个sqlserver数据库查询死锁异常

一、报错日志&#xff1a; Caused by: com.microsoft.sqlserver.jdbc.SQLServerException: 事务(进程 ID 117)与另一个进程被死锁在 锁 | 通信缓冲区 资源上&#xff0c;并且已被选作死锁牺牲品。请重新运行该事务。 二、数据库现象 注&#xff1a;下图中最后一条记录是解决后…

人工智能论文通用创新点(持续更新中...)

1.自注意力机制与卷积结合 论文&#xff1a;On the Integration of Self-Attention and Convolution 1&#xff1a;卷积可以接受比较大的图片的&#xff0c;但自注意力机制如果图片特别大的话&#xff0c;运算规模会特别大&#xff0c;即上图中右边(卷积)会算得比较快&#xf…

SpringMVC学习与开发(三)

注&#xff1a;此为笔者学习狂神说SpringMVC的笔记&#xff0c;其中包含个人的笔记和理解&#xff0c;仅做学习笔记之用&#xff0c;更多详细资讯请出门左拐B站&#xff1a;狂神说!!! 10、ssm整合 问了一下ChatGPT SSM 是一个基于 Java 的开发框架整合&#xff0c;由 Spring、…

以STM32为例,实现按键的短按和长按

以STM32为例&#xff0c;实现按键的短按和长按 目录 以STM32为例&#xff0c;实现按键的短按和长按1 实现原理2 实现代码3 测试结束语 1 实现原理 简单来说就是通过设置一个定时器来定时扫描几个按键的状态&#xff0c;并分别记录按键按下的持续时间&#xff0c;通过时间的长短…

k8s---声明式资源管理(yml文件)

在k8s当中支持两种声明资源的方式&#xff1a; 1、 yaml格式&#xff1a;主要用于和管理资源对象 2、 json格式&#xff1a;主要用于在API接口之间进行消息传递 声明式管理方法(yaml)文件 1、 适合对资源的修改操作 2、 声明式管理依赖于yaml文件&#xff0c;所有的内容都在y…

【致远FAQ】V8.0sp1_门户设置——页面组件中设置列表头的颜色

问题描述 门户设置——页面组件中设置列表头的颜色后&#xff0c;底表数据查看时的列表头颜色没有变呢 解决办法 设置不对cap4生效&#xff0c;只针对原始oa的列表支持&#xff08;比如协同工作——已办事项、公文等列表项&#xff09; 设置参考

uni-app 经验分享,从入门到离职(实战篇)——模拟从后台获取图片路径数据后授权相册以及保存图片到本地(手机相册)

文章目录 &#x1f4cb;前言⏬关于专栏 &#x1f3af;需求描述&#x1f3af;前置知识点&#x1f9e9;uni.showLoading()&#x1f9e9;uni.authorize()&#x1f9e9;uni.downloadFile()&#x1f9e9;uni.saveImageToPhotosAlbum() &#x1f3af;演示代码&#x1f9e9;关于图片接…

晓源|算法专栏

文章目录 数据结构1.栈1.1 单调栈1.2括号匹配问题 2.树形结构2.1二叉树2.1.1树形DP 3.动态规划3.1 背包3.2 LIS ERRORheap-buffer-overflow 数据结构 1.栈 1.1 单调栈 单调栈内的元素具有单调性质&#xff0c;要么单调递增&#xff0c;要么单调递减。 1.2括号匹配问题 921…

基于猫群算法优化的Elman神经网络数据预测 - 附代码

基于猫群算法优化的Elman神经网络数据预测 - 附代码 文章目录 基于猫群算法优化的Elman神经网络数据预测 - 附代码1.Elman 神经网络结构2.Elman 神经用络学习过程3.电力负荷预测概述3.1 模型建立 4.基于猫群优化的Elman网络5.测试结果6.参考文献7.Matlab代码 摘要&#xff1a;针…

MySQL中的事务到底是怎么一回事儿

简单来说&#xff0c;事务就是要保证一组数据库操作&#xff0c;要么全部成功&#xff0c;要么全部失败。在MySQL中&#xff0c;事务支持是在引擎层实现的&#xff0c;但并不是所有的引擎都支持事务&#xff0c;如MyISAM引擎就不支持事务&#xff0c;这也是MyISAM被InnoDB取代的…

xlrd.biffh.XLRDError: Can‘t find workbook in 0LE2 compound document

今天在运行之前可以正常运行的程序&#xff0c;解析excel文件&#xff0c;代码简单示例如下&#xff1a; import pandas as pddf pd.read_excel("F:\\1.xlsx")# 解析文件 不过&#xff0c;这次却遇到了一个问题&#xff0c;如下图&#xff1a; 第一次遇到这个错误…

QGIS设计导出Geoserver服务使用的SLD样式

1、打开QGis软件 2、打开shp文件所在所在文件夹&#xff0c;双击添加选中图层 3、编辑shp文件样式 &#xff08;1&#xff09;双击“Layers”中需要编辑的图层 &#xff08;2&#xff09;选择样式 &#xff08;3&#xff09;编辑样式后&#xff0c;选择“应用”—》“确定” 4…