vue3入门教程:reactive函数

devtools/2024/12/26 1:11:01/

基本用法

  1. 引入 reactive

    首先,你需要从 vue 包中引入 reactive 函数:

    javascript">import { reactive } from 'vue';
    
  2. 创建一个响应式对象

    使用 reactive 函数来创建一个响应式对象:

    javascript">const state = reactive({count: 0,name: 'Vue 3'
    });
    

    在这个例子中,state 是一个响应式对象,它包含了 countname 这两个属性。

  3. 在模板中使用

    在 Vue 组件的模板中,你可以直接访问响应式对象的属性:

    <template><div><p>Count: {{ state.count }}</p><p>Name: {{ state.name }}</p></div>
    </template>
    

    当这些属性发生变化时,模板将自动更新。

深层响应性

reactive() 提供的响应性是深层的,这意味着它可以处理嵌套的对象结构。例如:

javascript">const nestedState = reactive({user: {name: 'John',age: 30},posts: [{ title: 'Post 1', content: '...' },{ title: 'Post 2', content: '...' }]
});

在这个例子中,nestedState 是一个响应式对象,它包含一个名为 user 的响应式对象和一个名为 posts 的响应式数组。你可以像访问普通对象属性一样访问这些嵌套的响应式数据。

在组合式 API 中使用

reactive() 通常与 Vue 的组合式 API 一起使用,特别是在 setup 函数中:

javascript">import { reactive } from 'vue';export default {setup() {const state = reactive({count: 0,name: 'Vue 3'});function increment() {state.count++;}return {state,increment};}
};

在模板中,你可以直接访问 state 对象及其属性。

注意事项和局限性

  1. 仅支持对象类型reactive() 仅对对象类型有效(如对象、数组、Map、Set 等集合类型),对原始类型(如 String、Number、Boolean)无效。

  2. 解构赋值会丢失响应性:如果你对响应式对象进行解构赋值,解构出来的属性将失去其响应性。如果需要保持响应性,可以使用 toRefstoRef 函数。

  3. 避免直接替换响应式对象:如果你直接替换一个响应式对象(例如 state = reactive({...})),将会导致对初始引用的响应性连接丢失。

示例代码

以下是一个完整的示例,展示了如何在 Vue 组件中使用 reactive()

javascript"><template><div><p>Count: {{ state.count }}</p><p>Name: {{ state.name }}</p><button @click="increment">Increment</button></div>
</template><script>
import { reactive } from 'vue';export default {setup() {const state = reactive({count: 0,name: 'Vue 3'});function increment() {state.count++;}return {state,increment};}
};
</script>

在这个例子中,当点击按钮时,increment 函数会被调用,state.count 的值会增加,并且模板会自动更新以反映这个变化。

总结

reactive() 是 Vue 3 中用于创建响应式对象的强大工具。通过合理使用 reactive(),你可以更轻松地管理组件的状态,并实现数据的双向绑定和自动更新。


http://www.ppmy.cn/devtools/145402.html

相关文章

CSS @property 颜色过渡动画实例

CSS property 颜色过渡动画实例 基础知识 property 语法回顾 property --custom-color {syntax: <color>;inherits: false;initial-value: #ff0000; }颜色表示方式 在使用 property 进行颜色动画时&#xff0c;我们可以使用以下颜色格式&#xff1a; HEX: #RRGGBBRG…

Centos下的OpenSSH服务器和客户端

目录 1、在 IP地址为192.168.98.11的Linux主机上安装OpenSSH服务器&#xff1b; 2、激活OpenSSH服务&#xff0c;并设置开机启动&#xff1b; 3、在IP地址为192.168.98.33的Linux主机上安装OpenSSH客户端&#xff0c;使用客户端命令&#xff08;ssh、scp、sftp&#xff09;访…

负载均衡-lvs

负载均衡集群 1、集群是什么&#xff1f; 1 集群&#xff08;cluster&#xff09;技术是一种较新的技术&#xff0c;通过集群技术&#xff0c;可以在付出较低成本的情况下获得在性能、可靠性、灵活性方面的相对较高的收益&#xff0c;其任务调度则是集群系统中的核心技术。 …

FPGA 第13讲 计数器

时间:2024.12.14 一、学习内容 1.计数器 计数是一种最简单基本的运算,计数器就是实现这种运算的逻辑电路,计数器在数字 系统中主要是对脉冲的个数进行计数,以实现测量、计数和控制的功能,同时兼有分频功 能。 计数器在数字系统中应用广泛,如在电子计算机的控制器中对指…

微服务openfeign配置重试机制

场景&#xff1a; 1、在实际开发中&#xff0c;通过feign调用其他服务&#xff0c;如果出现read-timeout超时、或调用出现异常 2、如上问题&#xff0c;有时候可能是网络速度、网路抖动等原因导致超时异常&#xff0c;并非程序本身错误&#xff0c;所以可以配置openfeign重试…

什么是单例模式

单例模式就是 只有一个 不能存在多个 饿汉式单例模式 实现方式&#xff1a; 这种模式在程序启动或单例类被加载时就创建好实例。例如&#xff0c;以下是一个简单的 C 实现的饿汉式单例类&#xff0c;用于记录日志&#xff08;假设这个日志类在整个程序中有且仅有一个实例&#…

GitHub 桌面版配置 |可视化界面进行上传到远程仓库 | gitLab 配置【把密码存在本地服务器】

&#x1f947; 版权: 本文由【墨理学AI】原创首发、各位读者大大、敬请查阅、感谢三连 &#x1f389; 声明: 作为全网 AI 领域 干货最多的博主之一&#xff0c;❤️ 不负光阴不负卿 ❤️ 文章目录 桌面版安装包下载clone 仓库操作如下GitLab 配置不再重复输入账户和密码的两个方…

使用Python实现智能家居控制系统:开启智慧生活的钥匙

友友们好! 我的新专栏《Python进阶》正式启动啦!这是一个专为那些渴望提升Python技能的朋友们量身打造的专栏,无论你是已经有一定基础的开发者,还是希望深入挖掘Python潜力的爱好者,这里都将是你不可错过的宝藏。 在这个专栏中,你将会找到: ● 深入解析:每一篇文章都将…