《Vue设计与实现》第四章 第五节 调度执行(二)

1.《Vue设计与实现》第四章 第五节 调度执行(二)

我们要在上一章的基础上,实现一个功能。

const data = { foo:1 };
const obj = new Proxy(data, {
	get(){},
	set(){}
})

effect(() => {
	console.log(obj.foo);
})
obj.foo++;
obj.foo++;

输出

1,
2,
3,

由输出可知,字段obj.foo的值一定会从1自增到3,2只是它的过渡状态。如果我们只关心最终的结果而不关心过程,那么执行三次打印操作是多余的,我们期望的打印是:

1,
3

解决办法`

  1. 我们定义一个任务队列
  2. 一个标志代表是否正在刷新队列
  3. 创建一个 Promise实例,我们用它将一个任务添加到微任务队列中。

代码

const jobQueue = new Set(); // 一个任务队列
const p = Promise.resolve();
let isFlushing = false;
function flushJob() {
	if (isFlushing) return; // 保证队列正在刷新,则什么都不做。
	isFlushing = true;
	p.then(() => {
		jobQueue.forEach(item => item()); // 在微任务队列中执行jobQueuq队列任务。
	}).finally(() => {
		isFlushing = false;
	})
}

effect中

effect(() => {
	console.log(obj.foo);
},{
	scheduler(fn) {
		jobQueue(fn); // 将任务添加到队列中。
		flushJob(); // 刷新这个队列。
	}

})
```
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值