Vue3入门指北(三)ref和reactive

简介: Vue3入门指北(三)ref和reactive

前言


在Vue2.x中,我们只需要通过在data选项中定义我们需要使用的数据,这些数据就会变成响应式的数据,使用的时候会动态响应。但是如果你在data中声明一个对象时,你会发现,你对对象的属性进行增加或者删除等操作时,在使用时并不会进行相应的更改的。而在vue3中对这一响应式行为,进行全新的修改。下面就让我们看看,在vue3中是对于响应式的处理是如何的。


reactive()


我们可以使用 reactive() 函数创建一个响应式对象或数组:


在Vue3中,我们如果想要声明一个响应式的对象或者数组时,其提供了一个新的api来实现:


import { reactive } from 'vue'
const state = reactive({ count: 0 })
复制代码


通过reactive声明的对象,和普通对象一样。区别在于解决在vue2.x中对对象属性的增加或删除无法监听的问题,也就是说在vue3中通过其声明的对象,可以跟踪对象属性的增加或删除等操作。当然对实现原理感兴趣的话,可以查看官网和源码。


ref()


而如果你想得到一个响应式的变量。vue3也提供了一个新的api让我们对任何类型的数据,创建响应式的变量:


import { ref } from 'vue'
const count = ref(0)
复制代码


而对于响应式的变量访问或者修改等操作,需要通过.value形式来处理:


const count = ref(0)
console.log(count) // { value: 0 }
console.log(count.value) // 0
count.value++
console.log(count.value) // 1
复制代码


当然这么处理,也是因为 JavaScript对于基本数据类型,也就是值类型数据没用类似引用的机制。


不过,你在template中使用ref声明的响应式变量的时候,并不需要通过.value的形式,因为当 ref 在模板中作为顶层属性被访问时,它们会被自动“解包”。

相关文章
|
8天前
|
JavaScript 前端开发 开发者
vue3+ts配置跨域报错问题解决:> newpro2@0.1.0 serve > vue-cli-service serve ERROR Invalid options in vue.
【6月更文挑战第3天】在 Vue CLI 项目中遇到 "ERROR Invalid options in vue.config.js: ‘server’ is not allowed" 错误是因为尝试在 `vue.config.js` 中使用不被支持的 `server` 选项。正确配置开发服务器(如代理)应使用 `devServer` 对象,例如设置代理到 `http://xxx.com/`: ```javascript module.exports = { devServer: {
22 1
|
8天前
|
JavaScript 前端开发 数据安全/隐私保护
vue3+ts+elementplus写一个登录页面教程
【6月更文挑战第3天】本文介绍了如何使用 Vue 3 和 TypeScript 创建一个登录页面。首先,需安装 Vue CLI,然后创建新项目并启用 TypeScript 支持。接着,创建 `Login.vue` 组件,设计登录表单,包括用户账号、密码和验证码字段,并实现相关验证规则。页面样式包括背景、登录框和按钮等元素的布局与样式。最后,展示了`<script>`部分的代码,包括表单验证逻辑、生成验证码的函数以及登录提交处理。文章还提供了一个登录页面的截图和完整代码示例。
31 1
|
8天前
|
JavaScript API
vue3+element实现一个公告面板
vue3+element实现一个公告面板
36 0
vue3+element plus图片预览点击按钮直接显示图片的预览形式
vue3+element plus图片预览点击按钮直接显示图片的预览形式
|
JSON 前端开发 API
Vue3入门到精通--reactive以及reactive相关函数
Vue3入门到精通--reactive以及reactive相关函数
|
2天前
|
JavaScript 前端开发 Java
【vue实战项目】通用管理系统:作业列表
【vue实战项目】通用管理系统:作业列表
15 0
|
2天前
|
JavaScript API
【vue实战项目】通用管理系统:信息列表,信息的编辑和删除
【vue实战项目】通用管理系统:信息列表,信息的编辑和删除
12 2
|
2天前
|
JavaScript API
【vue实战项目】通用管理系统:信息列表,信息录入
【vue实战项目】通用管理系统:信息列表,信息录入
8 3
|
2天前
|
JavaScript 前端开发 API
【vue实战项目】通用管理系统:学生列表
【vue实战项目】通用管理系统:学生列表
12 2