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

相关推荐
朱建伟5 分钟前
大神尤雨溪再次出手,前端工具链整合--该文章是对vite plus官方README文档进行了翻译
前端·vite
vball7 分钟前
宏观数据从哪里来?——主流宏观经济数据库与API全景
前端
zhensherlock16 分钟前
Protocol Launcher 系列:Trae AI 编辑器的深度集成
javascript·人工智能·vscode·ai·typescript·编辑器·ai编程
吠品26 分钟前
Vue项目Moment.js引入优化:全局挂载与按需引入的深度解析与最佳实践
前端·javascript·vue.js
不甜情歌28 分钟前
JS 类型判断不用愁:4 种方法,覆盖所有场景
前端·javascript
ETA835 分钟前
状态管理没那么复杂:手写实现 Zustand 核心逻辑
前端·react.js
FanetheDivine39 分钟前
在react中使用signal
vue.js·react.js
用户2557788508141 分钟前
axios请求缓存
前端
夫瑞42 分钟前
TypeScript 直接编译成原生二进制,没有浏览器,没有 V8
前端
Talents43 分钟前
OpenLayers 7.5.2 判断点是否在区域边上
前端