Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

array-factory

Package Overview
Dependencies
Maintainers
1
Versions
3
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

array-factory

Array methods that only evaluate for each element when they're needed.

  • 0.2.1
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
0
Maintainers
1
Weekly downloads
 
Created
Source

array-factory Build Badge NPM Badge License Badge

Array methods that only evaluate for each element when they're needed.

Use

Why to use

If you have a large array and want to use array methods such as map or filter, it might noticably slow down the page while it's in progress. Using array-factory, each element is only checked with the function when it's actually needed.

// Double every value in an array using map

// Normal map
// Entire array is mapped at once
const giantArray = Array(100_000_000).fill(2)
const mapped = giantArray.map(el => el * 2)

for (const value of giantArray) {
  console.log(value)
}

// Factory map
// One element is mapped at a time
const giantArray = Array(100_000_000).fill(2)
const mapped = giantArray.factoryMap(el => el * 2)

for (const value of giantArray) {
  console.log(value)
}

This is done with the use of ES6 generators. Using the factory map code, the function el => el * 2 is only run on each value when that value is used.

Chaining functions

The added factory functions are also added to the Generator type they return. This means that you're able to chain these functions together, just like normal array methods:

const someArray = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
const mapped = someArray
  // Only even numbers
  .factoryFilter(el => el % 2 === 0)
  // Double every number
  .factoryMap(el => el * 2)

for (const value of mapped) {
  console.log(value)
}
// 4, 8, 12, 16, 20

Refactoring old code

If you are interested in using array-factory, the change is as simple as importing the library and replacing function calls with their factory versions.

// Old
const abc = [1, 2, 3]

for (const value of abc.map(el => el * 2)) {
  console.log(value)
}

// New
import 'array-factory' // ES6
require('array-factory') // CommonJS

const abc = [1, 2, 3]

for (const value of abc.factoryMap(el => el * 2)) {
  console.log(value)
}

Exported functions

Each factory function is also exported if you prefer to import each function instead.

import { factoryMap } from 'array-factory' // ES6
const { factoryMap } = require('array-factory') // CommonJS

const abc = [1, 2, 3]

for (const value of factoryMap(abc, el => el * 2)) {
  console.log(value)
}

Supported functions

OriginalFactory
mapfactoryMap
filterfactoryFilter
flatfactoryFlat
flatMapfactoryFlatMap

All supported functions are both exported and added to Array prototypes.

Documentation

Documentation for the main branch is hosted at https://array-factory.adamts.me. Documentation can be built from a cloned repository by running yarn doc.

Examples are available under each function on the docs.

Installation

In a Node project

To use in a Node project, add array-factory as a dependency.

# npm
npm install array-factory

# yarn
yarn add array-factory

You can then import and use functions:

import { factoryMap } from 'array-factory'

In a normal UserScript

In a UserScript that isn't built with some build tool, you can @require the library:

// @require     https://gitlab.com/MysteryBlokHed/array-factory/-/raw/main/array-factory.user.js

You can replace main with a specific release tag like v0.1.0 to require a specific version:

// @require     https://gitlab.com/MysteryBlokHed/array-factory/-/raw/v0.1.0/array-factory.user.js

Each release tag also has a minified version of the script available, which can be used by changing the file extension to .min.user.js:

// @require     https://gitlab.com/MysteryBlokHed/array-factory/-/raw/v0.1.0/array-factory.min.user.js

Functions are available on the global ArrayFactory object:

const { factoryMap } = ArrayFactory
Type declarations

The types included with the npm package still work when the library is @require'd. Just add the types as a dev dependency for a Node project or install them globally. With the package installed, include the following reference line somewhere in your TypeScript source file:

/// <reference types="array-factory" />

Building

Setup

Building this project requires Node.js and Yarn. To install dependencies, run:

yarn install

Build

To build the project, run:

yarn build

To automatically build when a source file is modified, run:

yarn dev

Built JS files and type declarations will be placed in the lib/ directory, and the UserScript will be placed in the root. The package.json file is configured to publish files in the lib/ directory to npm.

Test

To test the project, run:

yarn test

This project uses Jest for tests.

License

This project is licensed under either of

at your option.

This project was created from a template licensed under the MIT license (LICENSE or http://opensource.org/licenses/MIT).

FAQs

Package last updated on 08 May 2022

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc