Vue3中ref()使用方法详解

EchoLiner 2024-12-20 09:56:25编程技术
642

Vue3作为新一代的前端框架,在性能和易用性上都有了显著提升。其中,ref()函数是Vue3响应式系统中的一个重要组成部分,它主要用于创建一个响应式的引用对象。通过ref(),我们可以轻松地在Vue组件中管理状态,并实现数据的双向绑定。本文将深入解析Vue3中ref()的使用方法,帮助读者更好地理解和运用这一强大工具。

ref( ) 接受一个内部值,返回一个ref 对象,这个对象是响应式的、可更改的,且只有一个指向其内部值的属性 .value。

ref() 将传入参数的值包装为一个带 .value 属性的 ref 对象。

1、ref 对象是可更改的,即可以为 .value 赋予新的值

举例:

const a = ref(1);
// 为 a.value 赋予新的值
a.value = 2;
console.log("a--->", a);
console.log("a.value--->", a.value);

查看打印结果:

Vue3中ref()使用方法详解

2、ref 对象是响应式的,即所有对 .value 的操作都将被追踪,并且写操作会触发与之相关的副作用。

ref()方法允许创建可以使用任何值类型的响应式 ref

ref 的 .value 属性也是响应式的。

当ref的值为对象类型时,会用 reactive() 自动转换它的 .value。

举例:一个包含对象类型值的 ref 可以响应式地替换整个对象

const b = ref({ name: 'vue3' });
// 响应式替换
b.value = { name: 'vite' };
console.log("b--->", b);
console.log("b.value--->", b.value);

查看打印结果:

Vue3中ref()使用方法详解

ref 被传递给函数或是从一般对象上被解构时,不会丢失响应性:

const obj = {
  foo: ref(0),
  bar: ref(1)
}

// 该函数接收一个 ref
// 需要通过 .value 取值
// 但它会保持响应性
callSomeFunction(obj.foo);

// 仍然是响应式的
const { foo, bar } = obj;

总结:ref() 让我们能创造一种对任意值的 “引用”,并能够在不丢失响应性的前提下传递这些引用。这个功能很重要,因为它经常用于将逻辑提取到组合函数中。

3、ref 在模板中的解包

当 ref 在模板中作为顶层属性被访问时,它们会被自动“解包”,所以不需要使用 .value。

<script setup>
import { ref } from 'vue';
const a = ref(1);
</script>

<template>
  <!-- 无需 .value -->
  <div>a:{{ a }}</div>
</template>

⚠️请注意,仅当 ref 是模板渲染上下文的顶层属性时才适用自动“解包”。

<script setup>
import { ref } from 'vue';
const obj = {
  count: ref(1)
}
</script>

<template>
  <div>{{ obj.count + 1 }}</div> 
</template>

渲染的结果是 [object Object]1,因为 object.count 是一个 ref 对象

Vue3中ref()使用方法详解

可以通过将 count 改成顶层属性来解决这个问题:

<script setup>
import { ref } from 'vue';
const obj = {
  count: ref(1)
}
// 将 count 改成顶层属性
const { count } = obj;
</script>

<template>
  <div>{{ count + 1 }}</div>
</template>

渲染结果是 2

Vue3中ref()使用方法详解

⚠️如果一个 ref 是文本插值计算的最终值,它也将被解包

<script setup>
import { ref } from 'vue';
const obj = {
  count: ref(1)
}
const { count } = obj;
</script>

<template>
  <div>{{ count + 1 }}</div>
  <div class="count">{{ obj.count }}</div>
</template>

<div class="count">{{ obj.count }}</div>的渲染结果为 1

这只是文本插值的一个方便功能,相当于 {{ object.foo.value }}

Vue3中ref()使用方法详解

4、ref 在响应式对象中的解包

当一个 ref 被嵌套在一个响应式对象中,作为属性被访问或更改时,它会自动解包,因此会表现得和一般的属性一样:

import { ref, reactive } from 'vue';
const a = ref(0);
const obj = reactive({
  a
})
console.log("obj.a--->", obj.a);

obj.a = 2;
console.log("a.value--->", a.value);

查看打印结果:

Vue3中ref()使用方法详解

如果将一个新的 ref 赋值给一个关联了已有 ref 的属性,那么它会替换掉旧的 ref:

import { ref, reactive } from 'vue';
const a = ref(0);
const other = ref(1);
const obj = reactive({
  a
})
// 将一个新的 ref 赋值给一个关联了已有 ref 的属性
obj.a = other;
console.log("obj.a--->", obj.a);
// 原始 ref 现在已经和 obj.a 失去联系
console.log("a.value--->", a.value);

查看打印结果:

Vue3中ref()使用方法详解

只有当嵌套在一个深层响应式对象内时,才会发生 ref 解包。当其作为浅层响应式对象的属性被访问时不会解包。

5、ref在数组和集合类型的解包

跟响应式对象不同,当 ref 作为响应式数组或像 Map 这种原生集合类型的元素被访问时,不会进行解包。

import { ref, reactive } from 'vue';
const books = reactive([ref('Vue 3 Guide')]);
// 这里需要 .value
console.log(books[0].value);

const map = reactive(new Map([['count', ref(0)]]));
// 这里需要 .value
console.log(map.get('count').value);

6、ts为 ref() 标注类型

ref 会根据初始化时的值推导其类型:

import { ref } from 'vue'

// 推导出的类型:Ref<number>
const year = ref(2020)

// => TS Error: Type 'string' is not assignable to type 'number'.
year.value = '2020'

有时我们可能想为 ref 内的值指定一个更复杂的类型,可以通过使用 Ref 这个类型

import { ref } from 'vue'
import type { Ref } from 'vue'

const year: Ref<string | number> = ref('2020')

year.value = 2020 // 成功!

或者,在调用 ref() 时传入一个泛型参数,来覆盖默认的推导行为:

// 得到的类型:Ref<string | number>
const year = ref<string | number>('2020')

year.value = 2020 // 成功!

如果你指定了一个泛型参数但没有给出初始值,那么最后得到的就将是一个包含 undefined 的联合类型:

// 推导得到的类型:Ref<number | undefined>
const n = ref<number>()

总结

通过本文的介绍,我们详细了解了Vue3中ref()函数的使用方法及其背后的原理。ref()不仅可以用于创建响应式的引用对象,还可以与其他Vue特性结合使用,实现复杂的状态管理和数据绑定。掌握ref()的使用技巧,将有助于我们在实际项目中更高效地开发和维护代码。希望本文的内容能对读者有所帮助,让大家在Vue3的世界中游刃有余。

vue3 ref
THE END
蜜芽
故事不长,也不难讲,四字概括,毫无意义。

相关推荐

VTJ.PRO:AI驱动的企业级低代码开发平台,让Vue3开发更高效
VTJ.PRO是一款AI驱动的企业级低代码开发平台,专注于前端开发领域,基于Vue3 + TypeScript + Vite构建,深度融合可视化设计、源码工程与AI智能引擎,旨在解决传统开发中的效率...
2025-09-11 新闻资讯
543

JavaScript报错“Uncaught ReferenceError”如何解决?
在JavaScript开发中,“Uncaught ReferenceError”是常见且易混淆的错误类型。本文ZHANID工具网从错误本质、常见场景、排查步骤、解决方案四个维度,结合真实代码案例与调试技...
2025-09-09 编程技术
566

打开网页提示错误代码"ERR_CONNECTION_REFUSED"的原因及解决方法
在互联网使用过程中,用户常会遇到网页无法加载的情况,其中"ERR_CONNECTION_REFUSED"是典型的连接错误提示。该错误表明浏览器尝试与目标服务器建立连接时,服务器明确拒绝了...
2025-08-28 电脑知识
511

Vue3实现excel导出方法及性能优化实战指南
在Vue3生态中,Excel导出功能已成为企业级应用的核心需求。本文ZHANID工具网基于SheetJS(xlsx库)与Vue3的深度整合实践,结合性能优化策略,提供从基础实现到高阶优化的完整...
2025-07-03 编程技术
508

90%的站长没用好Ahrefs?这3个关键功能被严重忽视!
在SEO工具领域,Ahrefs凭借其强大的数据爬取能力和丰富的功能模块,已成为全球站长和数字营销从业者的标配工具。然而,超过90%的用户仅将其作为外链分析工具,却忽视了其核心...
2025-06-25 站长之家
376

Vue3中slot的使用方法及示例代码详解
在 Vue3 的组件化开发中,Slot(插槽)是实现内容分发的重要机制。它允许父组件向子组件传递模板内容,同时保持子组件的封装性和复用性。本文ZHANID工具网将系统讲解 Vue3 中...
2025-06-24 编程技术
419