reactive和ref函数
1. reactive
接受对象类型数据的参数传入并返回一个响应式的对象
<script setup>
// 导入
import { reactive } from 'vue'
// 执行函数 传入参数 变量接收
const state = reactive({
msg:'this is msg'
})
const setSate = ()=>{
// 修改数据更新视图
state.msg = 'this is new msg'//不需要.value
}
</script>
<template>
{{ state.msg }}
<button @click="setState">change msg</button>
</template>
2. ref
接收简单类型或者对象类型的数据传入并返回一个响应式的对象
<script setup>
// 导入
import { ref } from 'vue'
// 执行函数 传入参数 变量接收
const count = ref(0)
const setCount = ()=>{
// 修改数据更新视图必须加上.value
count.value++
}
</script>
<template>
<button @click="setCount">{{count}}</button>
</template>
注意:
-
ref函数创建响应式数据,返回值是一个对象
-
模版中使用ref数据,省略.value,js代码中不能省略(特殊:js中watch监听可以省)
3、reactive 对比 ref
-
都是用来生成响应式数据
-
不同点:
-
reactive不能处理简单类型的数据,只支持引用数据类型,ref支持基本和引用数据类型
-
ref通过.value获取数据,reactive不需要.value
-
ref创建响应式引用数据类型低层依赖reactive
-