From 7017c2d85bc3d5df81d25c8c06bab9948308447b Mon Sep 17 00:00:00 2001 From: Antonio Stoilkov Date: Thu, 11 Jan 2024 13:32:58 +0200 Subject: [PATCH] =?UTF-8?q?=E2=9C=8F=EF=B8=8F=20add=20`postTask()`=20imple?= =?UTF-8?q?mentation=20using=20`main-thread-scheduling`?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- readme.md | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/readme.md b/readme.md index c1d409f..848719a 100644 --- a/readme.md +++ b/readme.md @@ -129,6 +129,16 @@ There are two priorities available: `user-visible` and `background`: [`scheduler.postTask()`](https://developer.mozilla.org/en-US/docs/Web/API/Scheduler/postTask) is available in some browsers today. `postTask` is a great alternative, you just need to have a better understanding on its inner workings. `main-thread-scheduling` aims to be easier to use. For example, `main-thread-scheduling` uses the `isInputPending()` API to ensure the UI doesn't freeze when the user interacts with the page (if you use `scheduler.postTask()` you will need to do that manually). Also, if you have running animations while running your tasks, you will see `main-thread-scheduling` perform better. +If you want the benefits of `main-thread-scheduling`, but you prefer the `postTask()` API/thinking model, then here is an implementation of `postTask()` using `yieldOrContinue()`: +```ts +async function postTask(callback: () => void | Promise, options?: { + priority: SchedulingPriority +}) { + await yieldOrContinue(options?.priority ?? 'user-visible') + await callback() +} +``` + ### Web Workers Web Workers are a great fit if you have: 1) heavy algorithm (e.g. image processing), 2) heavy process (runs for a long time, big part of the app lifecycle). However, in reality, it's rare to see people using them. That's because they require significant investment of time due to the complexity that can't be avoided when working with CPU threads regardless of the programming language. This library can be used as a gateway before transitioning to Web Workers. In most cases, you would discover the doing it on the main thread is good enough.