vue3定义变量ref、reactive、toRefs的特征和应用
1.ref() 函数
ref() 函数用来根据给定的值创建一个响应式的数据对象,传入的为基本数据类型,例如字符串、数字、boolean 等,返回值是一个对象,这个对象上只包含一个 value 属性
ref定义的变量,改变值要.value,而且在template中不用写.value
<div>{{msg}}</div>
<button @click="changeMsg()">修改msg</button>
import {reactive,ref,toRefs} from 'vue'
setup() {
//定义
const msg = ref('你好')
//修改
const changeMsg =()=>{
msg.value ='msg被改了'
}
//导出
return {
msg,
changeMsg
}
}
2.reactive() 函数
reactive函数传入的为引用类型,例如数组、对象等,但不能代理基本类型值,返回一个响应式的数据对象, 想要使用创建的响应式数据也很简单,创建出来之后,在setup中return出去,直接在template中调用即可。
<div>{{state.msg}}</div>
<button @click="changeMsg()">修改msg</button>
import { reactive, ref, toRefs } from 'vue'
setup() {
//定义
const state = reactive({
msg: '你好',
msg2:'hello'
})
//修改
const changeMsg = () => {
state.msg = 'msg被改了'
}
//导出
return {
state,
changeMsg
}
}
3.toRefs() 函数
toRefs() 函数可以将 reactive() 创建出来的响应式对象,转换为普通的对象,相当于变成一个个的ref(),类似使用拓展用算符…的方法返回数据data
使用toRefs和reactive()区别在于可以直接使用msg属性,不用state.
<div>{{msg}}</div>
<button @click="changeMsg()">修改msg</button>
import { reactive, ref, toRefs } from 'vue'
setup() {
//定义
const state = reactive({
msg: '你好',
msg2:'hello'
})
//修改
const changeMsg = () => {
state.msg = 'msg被改了'
}
//导出
return {
...toRefs(state),
changeMsg
}
}
4.reactive和ref 区别
都是用作定义基本变量的
ref 定义简单的,reactive一般定义数组和对象
ref 有.value属性,reactive没有
注:有特殊的地方,就是正常我们在用const定义常量的时候,不能被修改,不可以再次赋值,它的指向是不可以改变的,只能指向某处固定区域,不能再指向其它地方
① 声明后必须初始化赋值,如:const name='aaa',不可以 const name;
② 常量的含义是指向的对象不能修改,但是可以修改对象中的属性
所以类似const userName = ref('张三')
userName.value = '李四'
实际上是在给对象userName的属性重新赋值
分类:
vue相关 / vue3
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
2022-03-29 echarts自适应大小
2022-03-29 element ui select 远程搜索 选中之后清空输入框