Vue3 响应式数据 reactive使用

ref 与 reactive 是 vue3 提供给我们用于创建响应式数据的两个方法。

reactive 常用于创建引用数据,例如:object、array 等。

reactive 则是通过 proxy 来实现的响应式数据,并配合 reflect 操作的源对象。

reactive 创建引用数据:

html 复制代码
<template>
  <p>姓名:{{ info.name }}</p>
  <p>年龄:{{ info.age }}</p>
  <p>性别:{{ info.sex }}</p>
  <button @click="editInfo">修改信息</button>
</template>

<script>
// 引入 reactive 函数
import { reactive } from 'vue'
export default {
  name: "Home",
  setup() {
    // 使用 reactive 创建引用数据
    const info = reactive({
      name: "张三",
      age: 20,
      sex: "男"
    });
    // 创建方法
    const editInfo = () => {
      info.name = "李四";
      info.age = 22;
      info.sex = "女";
      // reactive 创建的数据是一个 proxy 对象,不需要通过 value 获取
      console.log(info);
    }
    // 返回数据
    return {
      info,
      editInfo
    }
  }
}
</script>

reactive 只能创建引用数据(数组或对象)。另外通过 reactive 创建的数据可以直接使用,不需要通过 value 属性获取。

注:reactive 创建的是一个深层次的数据对象,不论多少层,reactive 都能检测到数据的变化

reactive 创建数组 :

html 复制代码
<template>
  <p v-for="item in userList" :key="item">{{ item }}</p>
  <button @click="editUser">修改人员</button>
</template>

<script>
// 引入 reactive 函数
import { reactive } from 'vue'
export default {
  name: "Home",
  setup() {
    // 使用 reactive 创建数组
    const userList = reactive(["张三", "李四", "王五"]);
    // 创建方法
    const editUser = () => {
      // vue3 通过下标修改数据时,页面也会实时更新
      userList[0] = "张三丰";
      console.log(userList);
    }
    // 返回数据
    return {
      userList,
      editUser
    }
  }
}
</script>

注:vue3 通过下标修改数据时,页面也会实时更新。

原创作者:吴小糖

创作时间:2023.11.23

相关推荐
自由与自然8 分钟前
栅格布局常用用法
开发语言·前端·javascript
Violet_YSWY16 分钟前
讲一下ruoyi-vue3的前端项目目录结构
前端·javascript·vue.js
这是你的玩具车吗17 分钟前
转型成为AI研发工程师之路
前端·ai编程
Drift_Dream19 分钟前
在Vue样式中使用JavaScript 变量(CSS 变量注入)
前端
C_心欲无痕19 分钟前
vue3 - toRaw获取响应式对象(如由reactive创建的)的原始对象
前端·javascript·vue.js
PlankBevelen19 分钟前
手搓实现简易版 Vue2 响应式系统
前端
LoveDreaMing21 分钟前
MCP入门梳理
前端·typescript·mcp
小林攻城狮22 分钟前
一个基于 canvas 的 pdf 图片分页切割方法
前端·javascript
老华带你飞24 分钟前
学生宿舍管理|基于java + vue学生宿舍管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
一天前25 分钟前
一个功能强大的 React Native 拖拽排序组件库,支持单列和多列布局,提供流畅的拖拽体验和自动滚动功能
前端