Vue3 响应式系统 - 2 - Computed实现思路

文章介绍了响应式系统中可调度性的重要性,以及如何通过scheduler控制副作用函数的执行。通过jobQueue实现了连续变更只触发一次的效果。接着讨论了lazy执行和computed函数的实现,以及计算属性的缓存策略,确保数据不变时避免重复计算。最后提到了在非Proxy对象上实现响应式更新的必要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 调度执行

可调度性是响应式系统非常重要的一个特性,所谓可调度性就是当trigger触发时 控制副作用函数的执行时机和执行次数的能力。比如连续更改data.a时,如果按照之前写的逻辑就会发现data.a改变了几次,副作用函数就触发了几次,这显然不是我们想要的结果。

data.a++

data.a++

data.a++

我们改进一下effect方法,多接收一个option对象,并挂在efectFn上方便拓展一些能力。

const effect = (fn, options = {}) => {
  const effectFn = () => {
    effectFn.deps.forEach(bucket => bucket.delete(effectFn));
    effectFn.deps = []
    effectStack.push(effectFn)

    activeFuction = effectFn
    const res = fn()
    effectStack.pop()
    activeFuction = effectStack[effectStack.length - 1]
    return res
  }
  effectFn.deps = []
  effectFn.options = options
  effectFn()
}

调用efeect方法传入option,option中有一个scheduler函数,然后在trigger方法内判断当前依赖是否有scheduler,有就执行scheduler并把当前依赖传入,否则执行依赖。


                
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值