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

相关推荐
jessezappy几秒前
jQuery-Word-Export 使用记录及完整修正文件下载 jquery.wordexport.js
前端·word·jquery·filesaver·word-export
旧林84328 分钟前
第八章 利用CSS制作导航菜单
前端·css
程序媛-徐师姐38 分钟前
Java 基于SpringBoot+vue框架的老年医疗保健网站
java·vue.js·spring boot·老年医疗保健·老年 医疗保健
yngsqq39 分钟前
c#使用高版本8.0步骤
java·前端·c#
Myli_ing1 小时前
考研倒计时-配色+1
前端·javascript·考研
余道各努力,千里自同风1 小时前
前端 vue 如何区分开发环境
前端·javascript·vue.js
PandaCave1 小时前
vue工程运行、构建、引用环境参数学习记录
javascript·vue.js·学习
软件小伟1 小时前
Vue3+element-plus 实现中英文切换(Vue-i18n组件的使用)
前端·javascript·vue.js
醉の虾2 小时前
Vue3 使用v-for 渲染列表数据后更新
前端·javascript·vue.js
张小小大智慧2 小时前
TypeScript 的发展与基本语法
前端·javascript·typescript