nonblocking-array

1.0.9 • Public • Published

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]

Package Sidebar

Install

npm i nonblocking-array

Weekly Downloads

12

Version

1.0.9

License

MIT

Unpacked Size

19.2 kB

Total Files

6

Last publish

Collaborators

  • elikemt