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

nonblocking-array

v1.0.9

Published

Provides nonblocking functions of various Array methods. Unlike the standard array methods that execute array iterations in its entirety in one cycle of the event loop and may block the event loop on large arrays, these functions execute each iteration of

Downloads

40

Readme

nonblocking-array

Provides nonblocking functions of various Array methods. Unlike the standard array methods that execute array iterations in its entirety in one cycle of the event loop, and may block the event loop on large arrays, these functions execute each iteration of the array in isolation (separate async functions) enabling the event loop to yield and handle other tasks while the large array operations/processing is in progress.

Browsers are supported from v1.0.8 and above.

Installation

Install using npm i nonblocking-array

Usage

The functions take at least two arguments. The first argument is the array to be processed and second argument is a callback function. The callback is called with the currentItem as the first argument, currentIndex as the second argument and the array as third argument. The functions are promised based and the callbacks can also be async functions.

Import/require as follows

const array = require("nonblocking-array");

Functions

map

Returns a new array with the results of the returned values of the callback function. Similar to Array.prototype.map.

const largeArray = [1, 2, 3, 4, 5]; //A large array that may block with regular Array.map
(async () => {
  const newArray = await array.map(largeArray, (element, index) => {
    //Do something with element
    return element * 2;
  });
  console.log(newArray); //Do something with the result of the map function
})();

forEach

Calls the callback function with each item and index of the array. forEach is promise based as of version 1.0.3 and can be used with the await keyword.

Returns undefined

array.forEach(largeArray, (currentItem, currentIndex) => {
  console.log(`Current Item: ${currentItem}, Current Index: ${currentIndex}`);
});

reduce

The reduce function behaves the exact same way the Array.prototype.reduce does. "The reduce() method executes a reducer function (that you provide) on each element of the array, resulting in a single output value."

const reducedValue = await array.reduce(
  largeArray,
  (accumulator, currentItem, index) => {
    return accumulator + currentItem;
  }
);
console.log(reducedValue);

The reduce function complies with the Array.prototype.reduce specification A value to use as the first argument to the first call of the callbackFn. If no initialValue is supplied, the first element in the array will be used as the initial accumulator value and skipped as currentValue. Calling reduce() on an empty array without an initialValue will throw a TypeError.

const reducedValue = await array.reduce(
  largeArray,
  (accumulator, currentItem, index) => {
    return accumulator + currentItem;
  },
  4
); // 4 specified as initial value
console.log(reducedValue);

filter

The filter function behaves the exact same way the Array.prototype.filter does. "The filter returns a new array of elements in the old array that passed the test provided in the callback function"

const numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9];
const filteredArray = await array.filter(largeArray, (element, index) => {
  return element > 5;
});
console.log(filteredArray); // [6, 7, 8, 9]