vue中ref与reactive区别与用法

简介: v

前言

在vue中refreactive是用于响应式数据的两种不同方式,ref和reactive是Vue.js框架中的两种关键概念。这两个概念都是用于实现响应式数据绑定的。


ref:

在Vue中,ref是一个用于在模板或实例中获取DOM元素或组件实例的特殊属性。ref属性可以被添加到任何Vue组件或HTML元素上,并且可以在组件或实例中使用$refs属性来访问它。

在Vue中,ref是一个用于在模板或实例中获取DOM元素或组件实例的特殊属性。ref属性可以被添加到任何Vue组件或HTML元素上,并且可以在组件或实例中使用$refs属性来访问它。

以下是一些ref的使用场景:

  1. 获取元素的值或属性:可以使用ref来获取表单元素的值或属性,例如获取input中的value。
  2. 调用子组件的方法:可以使用ref来获取子组件实例,并且可以调用子组件中的方法。
  3. 动态创建或删除子组件:可以使用ref来动态创建或删除子组件,并且可以在父组件中访问子组件实例。

下面是一个使用ref的例子:

在模板中:

<template>
  <div>
    <input type="text" ref="input">
    <button @click="getValue">获取值</button>
    <custom-component ref="custom"></custom-component>
  </div>
</template>

在脚本中:

<script>
export default {
  methods: {
    getValue() {
      const value = this.$refs.input.value;
      console.log(value);
    },
    callChildMethod() {
      this.$refs.custom.someMethod();
    },
    createComponent() {
      const component = new CustomComponent();
      this.$refs.custom.appendChild(component.$el);
    },
    deleteComponent() {
      this.$refs.custom.removeChild(component.$el);
    }
  }
}
</script>

在上面的例子中,我们可以使用ref属性来获取组件或元素并对其进行操作。可以通过使用$refs属性来访问它们。

reactive:

在Vue中,reactive是用于创建响应式数据的函数。它接收一个普通对象作为参数,并返回一个被代理的响应式对象。

当响应式对象中的属性被修改时,Vue会自动检测到这些变化并更新相关的视图。这种响应式的能力使得Vue的数据驱动视图更新非常方便。

例如:

import { reactive } from 'vue';
const state = reactive({
  count: 0
});
state.count++; // 视图会自动更新

在React中也有类似的功能,使用的是useStateuseReducer等Hook函数。但是需要注意的是,Vue对响应式的实现和React的实现有所不同,可能会导致一些React开发者感到不适应。

区别:

  1. ref是用于处理基本数据类型的,例如数字、字符串等。而reactive可以处理任何类型的数据,包括对象、数组等。
  2. ref返回的是一个代理对象,使用时需要访问它的value属性,例如:refData.value。而reactive返回的是一个响应式对象,可以直接访问它的属性。
  3. ref提供了一些特殊的方法,例如.value属性、.get()方法、.set()方法等。而reactive提供了一些额外的方法,例如.toRaw()方法、.markRaw()方法等。
  4. ref通常用于处理单一的数据,而reactive常用于处理复杂的数据结构,例如对象和数组。  

总结:

      ref适用于处理简单的数据类型,而reactive适用于处理复杂的数据结构。无论是处理简单类型的数据还是复杂类型的数据,Vue 3提供了适用的工具来满足不同的需求。

相关文章
|
1天前
|
存储 JavaScript 开发者
Vue 组件间通信的最佳实践
本文总结了 Vue.js 中组件间通信的多种方法,包括 props、事件、Vuex 状态管理等,帮助开发者选择最适合项目需求的通信方式,提高开发效率和代码可维护性。
|
1天前
|
存储 JavaScript
Vue 组件间如何通信
Vue组件间通信是指在Vue应用中,不同组件之间传递数据和事件的方法。常用的方式有:props、自定义事件、$emit、$attrs、$refs、provide/inject、Vuex等。掌握这些方法可以实现父子组件、兄弟组件及跨级组件间的高效通信。
|
6天前
|
JavaScript
Vue基础知识总结 4:vue组件化开发
Vue基础知识总结 4:vue组件化开发
|
6天前
|
存储 JavaScript
Vue 状态管理工具vuex
Vue 状态管理工具vuex
|
12天前
|
缓存 JavaScript UED
Vue 中实现组件的懒加载
【10月更文挑战第23天】组件的懒加载是 Vue 应用中提高性能的重要手段之一。通过合理运用动态导入、路由配置等方式,可以实现组件的按需加载,减少资源浪费,提高应用的响应速度和用户体验。在实际应用中,需要根据具体情况选择合适的懒加载方式,并结合性能优化的其他措施,以打造更高效、更优质的 Vue 应用。
|
12天前
|
JavaScript
如何在 Vue 中使用具名插槽
【10月更文挑战第25天】通过使用具名插槽,你可以更好地组织和定制组件的模板结构,使组件更具灵活性和可复用性。同时,具名插槽也有助于提高代码的可读性和可维护性。
15 2
|
12天前
|
JavaScript
Vue 中的插槽
【10月更文挑战第25天】插槽的使用可以大大提高组件的复用性和灵活性,使你能够根据具体需求在组件中插入不同的内容,同时保持组件的结构和样式的一致性。
14 2
|
12天前
|
前端开发 JavaScript 容器
在 vite+vue 中使用@originjs/vite-plugin-federation 模块联邦
【10月更文挑战第25天】模块联邦是一种强大的技术,它允许将不同的微前端模块组合在一起,形成一个统一的应用。在 vite+vue 项目中,使用@originjs/vite-plugin-federation 模块联邦可以实现高效的模块共享和组合。通过本文的介绍,相信你已经了解了如何在 vite+vue 项目中使用@originjs/vite-plugin-federation 模块联邦,包括安装、配置和使用等方面。在实际开发中,你可以根据自己的需求和项目的特点,灵活地使用模块联邦,提高项目的可维护性和扩展性。
|
12天前
|
缓存 JavaScript UED
Vue 中异步加载模块的方式
【10月更文挑战第23天】这些异步加载模块的方式各有特点和适用场景,可以根据项目的需求和架构选择合适的方法来实现模块的异步加载,以提高应用的性能和用户体验
|
12天前
|
JavaScript 测试技术 UED
解决 Vue 项目中 Tree shaking 无法去除某些模块
【10月更文挑战第23天】解决 Vue 项目中 Tree shaking 无法去除某些模块的问题需要综合考虑多种因素,通过仔细分析、排查和优化,逐步提高 Tree shaking 的效果,为项目带来更好的性能和用户体验。同时,持续关注和学习相关技术的发展,不断探索新的解决方案,以适应不断变化的项目需求。