Vue - ref( ) 和 reactive( ) 响应式数据的使用

一、ref( )

在 Vue 3 中,ref() 是一个用于创建响应式引用的函数。它是Vue 3 Composition API(组合式API) 的一部分,允许在组件中创建响应式数据

使用对象:基本数据类型(String 、Number 、Boolean 、Null 等)、对象类型

****需要使用 . value

1.引入ref () 函数

javascript 复制代码
// 引入
import { ref } from 'vue';

2. 创建响应式引用

javascript 复制代码
// 定义 响应式数据  在 <script> 标签中
// 在 <script> 标签中写的 JS 代码 , 都需要写 .value 来获取值
const name = ref('张三');
const age = ref(20);
const tel = '123xxxxxxxxxx';

const count = ref(0); // 创建一个响应式的数字
const message = ref('Hello, Vue 3!'); // 创建一个响应式的字符串

3. 访问和修改引用的值

javascript 复制代码
// 访问和修改引用的值

// 使用 ref() 创建的响应式引用会返回一个对象

// 该对象有一个 .value 属性来访问和修改其值

console.log(count.value); // 0
count.value++; // 修改值
console.log(count.value); // 1

4. 在模板中的使用

javascript 复制代码
<template>

// 在模板中,不需要使用 .value 。当在模板中使用时,ref 会自动解包

    <div class="person">
        <h2>姓名:{
  
  { name }}</h2>
        <h2>年龄:{
  
  { age }}</h2>
        <h2>地址:{
  
  { tel }}</h2>
        <button @click="changeName">修改名字</button>
        <button @click="changeAge">修改年龄</button>
        <button @click="showTel">查看电话</button>

        <p>{
  
  { count }}</p> <!-- 直接使用 count -->
        <button @click="count++">Increment</button>

    </div>
    
</template>

5. 与对象的结合使用

javascript 复制代码
const user = ref({
  name: 'Alice',
  age: 25,
});

// 访问和修改对象属性
console.log(user.value.name); // Alice
user.value.age++; // 修改属性
console.log(user.value.age); // 26

当我们在模板中使用了 ref 时,在改变了 这个 ref 的值时,Vue 会自动检测到这个变化,并且相应地更新 DOM。

ref ( ) 是基于 reactive( ) 编写的。

二、reactive( )

Vue 3 中,reactive() 是一个用于创建响应式对象的函数。它是 Vue 3 组合式 API 的一部分,允许开发者将普通对象转换为响应式对象,从而在数据变化时自动更新视图。

使用对象:对象类型

****需要使用 . value

1.导入 reactive ( ) 函数

javascript 复制代码
// 从 Vue 中导入
import { reactive } from 'vue';

2.创建响应式对象

javascript 复制代码
// 创建响应式对象
const state = reactive({
    count: 0,
    message: 'Hello, Vue 3!',
});

3. 访问和修改响应式属性

javascript 复制代码
// 访问和修改响应式属性
// 可以像访问普通对象一样访问和修改响应式对象的属性。
// Vue 会自动追踪这些属性的变化,并在它们变化时更新视图。

console.log(state.count); // 0
state.count++; // 修改属性
console.log(state.count); // 1

4. 支持嵌套对象的响应性:

javascript 复制代码
const state = reactive({
    user: {
        name: 'Alice',
        age: 25,
    },
});

// 访问嵌套属性
console.log(state.user.name); // Alice

// 修改嵌套属性
state.user.age++;
console.log(state.user.age); // 26

三、ref( ) 与 reactive( ) 的区别:

  • ref() 返回一个包含 .value 属性的对象,而 reactive() 返回的是一个直接可用的响应式对象。
  • reactive 重新分配一个新对象,会失去响应式。(可以使用Object.assign 来整体替换)。
  • 使用原则:
    • 若需要一个基本类型的响应式数据,必须使用 ref ;
    • 若需要一个响应式对象,层级不深,ref ,reactive 都可以使用;
    • 若需要一个响应式对象,且层级较深,推荐使用 reactive。
相关推荐
腾讯TNTWeb前端团队6 小时前
helux v5 发布了,像pinia一样优雅地管理你的react状态吧
前端·javascript·react.js
范文杰9 小时前
AI 时代如何更高效开发前端组件?21st.dev 给了一种答案
前端·ai编程
拉不动的猪9 小时前
刷刷题50(常见的js数据通信与渲染问题)
前端·javascript·面试
拉不动的猪10 小时前
JS多线程Webworks中的几种实战场景演示
前端·javascript·面试
FreeCultureBoy10 小时前
macOS 命令行 原生挂载 webdav 方法
前端
uhakadotcom11 小时前
Astro 框架:快速构建内容驱动型网站的利器
前端·javascript·面试
uhakadotcom11 小时前
了解Nest.js和Next.js:如何选择合适的框架
前端·javascript·面试
uhakadotcom11 小时前
React与Next.js:基础知识及应用场景
前端·面试·github
uhakadotcom11 小时前
Remix 框架:性能与易用性的完美结合
前端·javascript·面试
uhakadotcom11 小时前
Node.js 包管理器:npm vs pnpm
前端·javascript·面试