伊春网站推广,广东省建设部网站,做任务网站建设,做网站分为竞价和优化什么是ref与reactive
ref与reactive都是Vue3.0中新增的API#xff0c;用于响应式数据的处理。
1. ref
ref是一个函数#xff0c;可以用于将一个普通的数据类型转换成响应式数据。ref返回一个包含value属性的对象#xff0c;通过修改value属性的值#xff0c;可以触发组件…什么是ref与reactive
ref与reactive都是Vue3.0中新增的API用于响应式数据的处理。
1. ref
ref是一个函数可以用于将一个普通的数据类型转换成响应式数据。ref返回一个包含value属性的对象通过修改value属性的值可以触发组件更新。
使用方式如下
import { ref } from vueconst count ref(0)// 获取值
console.log(count.value)// 修改值
count.value// 在模板中使用
templatediv{{ count }}/div
/template2. reactive
reactive是一个函数用于将一个普通的对象转换成响应式数据。reactive返回一个响应式的Proxy对象通过修改该对象的属性值可以触发组件更新。
使用方式如下
import { reactive } from vueconst state reactive({count: 0,name: Tom
})// 获取值
console.log(state.count)// 修改值
state.count// 在模板中使用
templatediv{{ state.count }}/div
/template区别: ref只能用于将基本类型数据转换成响应式数据而reactive可以将任意对象转换成响应式数据。 ref返回一个包含value属性的对象而reactive返回一个响应式的Proxy对象。 在使用上ref更方便一些使用起来更简单直观。而reactive比较灵活可以将任意对象转换成响应式数据并且可以进行深层次的响应式处理。
reactive() API 有一些局限性
有限的值类型
它只能用于对象类型 (对象、数组和如 Map、Set 这样的集合类型)。它不能持有如 string、number 或 boolean 这样的原始类型。
不能替换整个对象
由于 Vue 的响应式跟踪是通过属性访问实现的因此我们必须始终保持对响应式对象的相同引用。这意味着我们不能轻易地“替换”响应式对象因为这样的话与第一个引用的响应性连接将丢失
let state reactive({ count: 0 })// 上面的 ({ count: 0 }) 引用将不再被追踪
// (响应性连接已丢失)
state reactive({ count: 1 })对解构操作不友好
当我们将响应式对象的原始类型属性解构为本地变量时或者将该属性传递给函数时我们将丢失响应性连接
const state reactive({ count: 0 })// 当解构时count 已经与 state.count 断开连接
let { count } state
// 不会影响原始的 state
count// 该函数接收到的是一个普通的数字
// 并且无法追踪 state.count 的变化
// 我们必须传入整个对象以保持响应性
callSomeFunction(state.count)需要注意的是使用ref和reactive时不能直接修改属性值的方式来更新数据而是应该通过修改value或Proxy对象的属性来触发组件更新。例如
// ref使用示例
const count ref(0)
count // 这样是错误的应该使用count.value// reactive使用示例
const state reactive({count: 0
})
state.count // 这样是正确的会触发组件更新