当前位置:首页 > 科技  > 软件

Vue3 新玩法!我能操控计算属性 Computed!

来源: 责编: 时间:2024-05-27 08:52:59 86观看
导读背景最近在做一个需求的时候,用到了一个 Vue3 内置的 API,发现真的非常实用,分享给大家。需求是这样的,我有一个变量 sum,是通过computed去计算的,且 sum 依赖的变量有的是响应式的,有的不是响应式的,所以会造成以下的后果,当

背景

最近在做一个需求的时候,用到了一个 Vue3 内置的 API,发现真的非常实用,分享给大家。wt528资讯网——每日最新资讯28at.com

需求是这样的,我有一个变量 sum,是通过computed去计算的,且 sum 依赖的变量有的是响应式的,有的不是响应式的,所以会造成以下的后果,当非响应式变量改变时,并不会触发sum 的响应式更新,只有响应式变量改变时才会触发sum的响应式更新。wt528资讯网——每日最新资讯28at.com

图片图片wt528资讯网——每日最新资讯28at.com

所以我需要用到一个 Vue3 的内置 API,它就是customRef。wt528资讯网——每日最新资讯28at.com

customRef

创建一个自定义的 ref,显式声明对其依赖追踪和更新触发的控制方式。wt528资讯网——每日最新资讯28at.com

类型

图片图片wt528资讯网——每日最新资讯28at.com

详细信息

customRef() 预期接收一个工厂函数作为参数,这个工厂函数接受 track 和 trigger 两个函数作为参数,并返回一个带有 get 和 set 方法的对象。wt528资讯网——每日最新资讯28at.com

一般来说,track() 应该在 get() 方法中调用,而 trigger() 应该在 set() 中调用。然而事实上,你对何时调用、是否应该调用他们有完全的控制权。wt528资讯网——每日最新资讯28at.com

实践小案例:防抖 Ref

创建一个防抖 ref,即只在最近一次 set 调用后的一段固定间隔后再调用:wt528资讯网——每日最新资讯28at.com

图片图片wt528资讯网——每日最新资讯28at.com

在组件中使用:wt528资讯网——每日最新资讯28at.com

图片图片wt528资讯网——每日最新资讯28at.com

可控的 computed

图片图片wt528资讯网——每日最新资讯28at.com

再回到一开始的话题,我遇到的问题是:当非响应式变量改变时,并不会触发sum 的响应式更新,只有响应式变量改变时才会触发sum的响应式更新。wt528资讯网——每日最新资讯28at.com

所以我们需要当非响应式变量count1、count2改变的时候,去手动触发 computed 的计算,这样才能更新 sum,但是 computed 返回的不是一个函数啊,我们要怎么去手动触发计算呢?wt528资讯网——每日最新资讯28at.com

所以这时候就需要一个可控的 computed,它拥有以下功能:wt528资讯网——每日最新资讯28at.com

1、能根据响应式变量去自动触发计算更新wt528资讯网——每日最新资讯28at.com

2、提供一个方法让用户手动去调用触发更新wt528资讯网——每日最新资讯28at.com

期望使用方式是这样的:wt528资讯网——每日最新资讯28at.com

图片图片wt528资讯网——每日最新资讯28at.com

具体的代码实现如下:wt528资讯网——每日最新资讯28at.com

图片 图片 wt528资讯网——每日最新资讯28at.com

本文链接://www.dmpip.com//www.dmpip.com/showinfo-26-90851-0.htmlVue3 新玩法!我能操控计算属性 Computed!

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 智启未来、共创锡望 —— 巴可 (Barco) 无锡开业典礼盛大举行

下一篇: 再探泛型 API,感受 Python 对象的设计哲学

标签:
  • 热门焦点
Top
Baidu
map