vue3.0里给数据添加响应式有很多api可用。
文章内容转载
https://blog.csdn.net/u010059669/article/details/112287552
reactive
reactive 用于为对象添加响应式状态。接收一个js对象作为参数,返回一个具有响应式状态的副本。
- 获取数据值的时候直接获取,不需要加.value
- 参数只能传入对象类型
const {ref,reactive,toRefs}=Vue //从Vue封装中导入
const app = Vue.createApp({
template: `
<div>
<h2>type:--->{{job.type}}</h2>
<h2>salary:-->{{job.salary}}</h2>
</div>
`,
setup(props) {
let job = reactive({type:'UI',salary:20})
setTimeout(() => {
job.type='come on',
job.salary=666
console.log(job)
}, 2000);
return {job}
}
})
const vm = app.mount("#app")
ref
ref 用于为数据添加响应式状态。由于reactive只能传入对象类型的参数,而对于基本数据类型要添加响应式状态就只能用ref了,同样返回一个具有响应式状态的副本。
- 获取数据值的时候需要加.value。(对于基本数据类型,ref是自己的实现方式且性能优于reactive,而对于对象类型,ref仍然是通过reactive包装实现的)
- 参数可以传递任意数据类型,传递对象类型时也能保持深度响应式,所以适用性更广。
- vue 3.0 setup里定义数据时推荐优先使用ref,方便逻辑拆分和业务解耦。
const {ref}=Vue //从Vue封装中导入
const app = Vue.createApp({
template: `
<div>
<h1>我的信息</h1>
<h2>姓名:{{name}}</h2>
<h2>年龄:{{age}}</h2>
<h2>type:{{job.type}}</h2>
<h2>salary:{{job.salary}}</h2>
</div>
`,
setup(props) {
let name = ref('andy')
let age = ref(22)
let job = ref({ //proxy代理对象
type:'UI设计师',
salary:20
})
setTimeout(() => {
job.value.type='come on',
job.value.salary=666
console.log(job)
}, 2000);
return {name,age,job}
}
})
toRef
toRef 用于为源响应式对象上的属性新建一个ref,从而保持对其源对象属性的响应式连接。接收两个参数:源响应式对象和属性名,返回一个ref数据。例如使用父组件传递的props数据时,要引用props的某个属性且要保持响应式连接时就很有用。
- 获取数据值的时候需要加.value
- toRef后的ref数据不是原始数据的拷贝,而是引用,改变结果数据的值也会同时改变原始数据
toRefs
toRefs 用于将响应式对象转换为结果对象,其中结果对象的每个属性都是指向原始对象相应属性的ref。常用于es6的解构赋值操作,因为在对一个响应式对象直接解构时解构后的数据将不再有响应式,而使用toRefs可以方便解决这一问题。
- 获取数据值的时候需要加.value
- toRefs后的ref数据不是原始数据的拷贝,而是引用,改变结果数据的值也会同时改变原始数据
- 作用其实和 toRef 类似,只不过 toRef 是一个个手动赋值,而 toRefs 是自动赋值。
const {reactive,toRefs}=Vue //从Vue封装中导入
const app = Vue.createApp({
template: `
<div>
<h1>我的信息</h1>
<h2>type:{{job.type}}--->{{type}}</h2>
<h2>salary:{{job.salary}}-->{{salary}}</h2>
</div>
`,
setup(props) {
let job = reactive({type:'UI',salary:20})
let{type,salary} = toRefs(job)//可直接通过属性访问,不需要从对象名字中引用
setTimeout(() => {
job.type='come on' //toRefs写法
job.salary=666
console.log(job)
}, 2000);
return {job,type,salary}
}
})
结语
尽量不要混着用,reactive和ref选一种,toRef和toRefs选一种,不然代码会很乱,推荐ref和toRefs一把梭。