ref、reactive、toRef、toRefs

ref

作用:定义一个响应式数据

语法:const xxx = ref(initValue)

创建一个包含响应式数据的引用对象

js中操作数据:xxx.value

模板中读取数据:不需要.value,直接<div>{{xxx}}</div>

接收的数据:基本类型、对象类型

基本类型的数据:响应式是靠object.defineProperty()的get与set完成的

对象类型的数据:通过vue3.0的一个新函数--reactive函数包装实现的

import { ref } from 'vue'

// 为基本数据类型添加响应式状态

const name = ref('张三')

// 为复杂数据类型添加响应式状态

const state = ref({

count: 0

})

// 打印name的值

console.log(name.value)

// 打印count的值

console.log(state.value.count)

reactive

作用:定义一个对象类型的响应式数据

语法:const 代理对象= reactive(源对象)接收一个对象(或数组),返回一个代理对象(Proxy的实例对象,简称proxy对象)

操作数据与读取数据:均不需要.value。

reactive定义的响应式数据是"深层次的"

内部基于ES6的Proxy实现,通过代理对象操作对象内部数据进行操作

import { reactive } from 'vue'

// 响应式状态

const state = reactive({

count: 0

})

// 打印count的值

console.log(state.count)

toRef

作用:创建一个ref对象,其value值指向另一个对象中的某个属性。

语法:const name = toRef(person,'name')

获取数据值的时候需要加.value

toRef后的ref数据不是原始数据的拷贝,而是引用,改变结果数据的值也会同时改变原始数据

应用:要将响应式对象中的某个属性单独提供给外部使用时。

import { defineComponent, toRef } from 'vue'

export default defineComponent({

props: [title],

setup (props) {

// 创建变量myTitle

const myTitle = toRef(props, 'title')

console.log(myTitle.value)

}

})

toRefs

作用:批量创建多个 ref 对象

语法:toRefs(person)

获取数据值的时候需要加.value

toRefs后的ref数据不是原始数据的拷贝,而是引用,改变结果数据的值也会同时改变原始数据

应用:常用于es6的解构赋值操作,因为在对一个响应式对象直接解构时解构后的数据将不再有响应式,而使用toRefs可以方便解决这一问题。

import { defineComponent, toRefs } from 'vue'

export default defineComponent({

props: [title],

setup (props) {

// 使用了解构赋值语法创建了变量myTitle

const { myTitle } = toRefs(props)

console.log(myTitle.value)

}

})

相关推荐
AI浩6 小时前
【Labelme数据操作】LabelMe标注批量复制工具 - 完整教程
运维·服务器·前端
涔溪7 小时前
CSS 网格布局(Grid Layout)核心概念、基础语法、常用属性、实战示例和进阶技巧全面讲解
前端·css
2401_878454537 小时前
浏览器工作原理
前端·javascript
西陵7 小时前
为什么说 AI 赋能前端开发,已经不是选择题,而是必然趋势?
前端·架构·ai编程
by__csdn8 小时前
Vue3 setup()函数终极攻略:从入门到精通
开发语言·前端·javascript·vue.js·性能优化·typescript·ecmascript
天天扭码9 小时前
前端如何实现RAG?一文带你速通,使用RAG实现长期记忆
前端·node.js·ai编程
一条可有可无的咸鱼9 小时前
企业招聘信息,企业资讯进行公示
java·vue.js·spring boot·uni-app
Luna-player9 小时前
在前端中,<a> 标签的 href=“javascript:;“ 这个是什么意思
开发语言·前端·javascript
lionliu05199 小时前
js的扩展运算符的理解
前端·javascript·vue.js
小草cys9 小时前
项目7-七彩天气app任务7.4.2“关于”弹窗
开发语言·前端·javascript