小编同样和大家分享对于Vue3中的数据相应的问题,之前,咱们写过这样的例子
Vue.createApp({
template: `<div>{{ nameObj.name }}</div>`,
setup() {
const { reactive } = Vue
const nameObj = reactive({name:'lilei',age:18})
setTimeout(() => {
nameObj.name = 'hanmeimei'
},2000)
return {
nameObj
}
}
}).mount('#root')
这个时候咱们可能联想到了es6中对于解构赋值的内容,咱们是不是能够将下面例子中的nameObj通过后果解构的形式获取外部的name,而后间接将name返回呢?也就是将代码写成这样
Vue.createApp({
template: `<div>{{ name }}</div>`,
setup() {
const { reactive,toRefs } = Vue
const nameObj = reactive({name:'lilei',age:18})
let { name } = nameObj
setTimeout(() => {
name.value = 'hanmeimei'
},2000)
return {
name
}
}
}).mount('#root')
在理论运行中,咱们发现,页面上的内容并没有变成hanmeimei,这个时候,咱们须要引入Vue3中的另外一个内容,咱们应该把代码批改成这样,能力实现数据和页面的响应式
Vue.createApp({
template: `<div>{{ name }}</div>`,
setup() {
const { reactive,toRefs } = Vue
const nameObj = reactive({name:'lilei',age:18})
let { name } = toRefs(nameObj)
setTimeout(() => {
name.value = 'hanmeimei'
},2000)
return {
name
}
}
}).mount('#root')
同样,和toRefs很相似的还有toRef,代码实例是这样的
Vue.createApp({
template: `<div>{{ age }}</div>`,
setup() {
const { reactive,toRef } = Vue
const nameObj = reactive({name:'lilei'})
let age = toRef(nameObj,'age')
setTimeout(() => {
age.value = 'hanmeimei'
},2000)
return {
age
}
}
}).mount('#root')
又是前端提高的一天,一起加油!
大家还能够关注我的微信公众号,蜗牛全栈。
发表回复