npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

task-worklet

v0.1.1

Published

Streamlined processing of tasks in a shared threadpool.

Downloads

38

Readme

Task Worklet

A polyfill for Task Worklet - a proposed API for defining and invoking coordinated, threadpooled background tasks with minimal transfer overhead.

Motivation

A lot of what we do in modern web applications touches the DOM in some way. Improving the performance of DOM-bound code is difficult because issues generally stem from layout and paint cost rather than actual script execution overhead. Task Worklet attempts to define a highly ergonomic way to offload all of the work an application needs to do that doesn't rely on the DOM, while making it incredibly easy to move data between the UI thread and background threads.

In addition to ergonomics, the design of Task Worklet allows for an implicit data flow graph to be formed based on how tasks are linked together to form dependencies on one another. When combined with pooling and a centralized registry for task processors, this enables an algorithm to distribute work across multiple threads, automatically maximizing concurrency and minimizing transfer overhead.

Demo: Realtime JS compilation, bundling & compression

Usage

First, install the script via npm install task-worklet or grab it from unpkg.

By default, the task-worklet ships as an npm module that exports the TaskQueue interface.

If you'd prefer to "install" it as window.TaskQueue, go for task-worklet/polyfill:

<script src="https://unpkg.com/task-worklet/polyfill"></script>

Once you have it imported/installed, we can start interacting with the TaskQueue:

// create a queue a max threadpool size of 1:
const queue = new TaskQueue();

// add a Task Worklet:
queue.addModule('/fetch-worklet.js').then(() => { /* loaded */ })

const task = queue.postTask('fetch', 'https://example.com/data.json');

console.log(task.state);  // pending

await sleep(1);

console.log(task.state);  // scheduled

// now we'll ask for the result back. This bumps up the priority
// of the task and sends its result to the main thread once complete:
const result = await task.result;
console.log(result)  // { ..some data.. }

Here's the key: task.result is a lazy getter. If you don't ask for a Task's result by accessing .result, it will be kept in whatever background thread ran the task until it's needed.

Why keep task results in the thread that ran the task? That's the best part: we can pass Task instances to postTask(), and instead of "pulling" the result of a task back to the main thread and sending it on to the thread that's running that second task, the second task will be routed to the thread that already has the first's result waiting:

const data = q.postTask('fetch', 'https://example.com/data.json');

const subset = q.postTask('filter', data, ['items', 'count']);

// we only end up with the subsetted data on the main thread:
console.log(await subset.result);