vue3-02声明响应式状态ref()
创始人
2024-12-01 01:04:08

一、使用

组合式 API 中,推荐使用 ref() 函数来声明响应式状态,例如

import { ref } from 'vue' const count = ref(0) 

注意点1:若想获取ref定义的参数,必须获取参数的value值,
比如:

console.log('count', count) // 打印的是{ value: 0 } console.log('count.value', count.value) // 打印的是0 

注意点2:注意,在模板中使用 ref 时,我们不需要附加 .value,
当在模板中使用时,ref 会自动解包 (有一些注意事项),可以直接在事件监听器中改变一个 ref,例如

  

1、ref 自动解包 (注意事项)

在模板渲染上下文中,只有顶级的 ref 属性才会被解包。
在下面的例子中,count 和 object 是顶级属性,但 object.id 不是:

const count = ref(0) const object = { id: ref(1) } 

因此,

{{ count + 1 }} // 预期工作-得到的结果是1 {{ object.id + 1 }} // 不会预期工作 -- 得到的结果是[object Object]1 

因为在计算表达式时 object.id 没有被解包,仍然是一个 ref 对象。为了解决这个问题,我们可以将 id 解构为一个顶级属性

const { id } = object {{ id + 1 }}// 预期工作,结果是2 

另一个需要注意的点是,如果 ref 是文本插值的最终计算值 (即 {{ }} 标签),那么它将被解包,因此以下内容将渲染为 1

{{ object.id }} // 该特性仅仅是文本插值的一个便利特性,等价于 {{ object.id.value }}。 

2、深层响应性

Ref 可以持有任何类型的值,包括深层嵌套的对象、数组或者 JavaScript 内置的数据结构,比如 Map。

Ref 会使它的值具有深层响应性。这意味着即使改变嵌套对象或数组时,变化也会被检测到:

import { ref } from 'vue'  const obj = ref({   nested: { count: 0 },   arr: ['foo', 'bar'] })  function mutateDeeply() {   // 以下都会按照期望工作   obj.value.nested.count++   obj.value.arr.push('baz') } 

非原始值将通过 reactive() 转换为响应式代理,

3、练习所有代码

    

相关内容

热门资讯

四部门印发行动方案,促进人工智... 近日,国家能源局会同国家发展改革委、工业和信息化部、国家数据局印发《关于促进人工智能与能源双向赋能的...
瞄准8时13分!一起看发射场准... 我国将于5月11日8时13分发射天舟十号货运飞船。目前,长征七号遥十一运载火箭已完成推进剂加注。 距...
天舟十号货运飞船点火发射 今天上午,搭载天舟十号货运飞船的长征七号遥十一运载火箭,在我国文昌航天发射场点火发射。
原创 微... 前段时间 iOS 微信发布了 8.0.73 正式版,安卓微信发布了 8.0.72 测试版,这次的更新...
任正非罕见出镜:华为芯片基础技... 感谢IT之家网友 的线索投递! 5 月 10 日消息,在 5 月 8 日播出的《新闻联播》节目中,...