A simple library for manipulating generators and arrays in JavaScript.
Install using Yarn:
yarn add @njlr/seqInstall using NPM:
npm install --save @njlr/seqYou can browse the documentation on GitHub.
- Some of the built-in Array functions are mutating (e.g.
Array.prototype.sort). - Many array functions are missing. Where is
Array.prototype.flatMap? - A chain of array functions creates a new array at every stage: the operations are not lazy.
- lodash and friends require either a wrapper object or binding for chaining calls. We use the pipeline operator (
|>) to achieve this at compile-time! - This package is a good citizen. It has no dependencies and does not mutate any global objects.
- The code is simple. You can review the whole thing in about an hour.
import * as seq from '@njlr/seq';
const xs = [ 1, 5, 1, 2, 7, 3, 3, 4, 5, 0 ]
|> seq.unique()
|> seq.map(x => x * 2)
|> seq.filter(x => x > 4)
|> seq.sorted()
|> seq.toArray;
// xs is [ 6, 8, 10, 14 ]Since seq works on iterables, you can also use for...of loops:
import * as seq from '@njlr/seq';
for (const x of seq.range(10) |> seq.map(x => x * x)) {
console.log(x);
}This library also plays nicely with spread syntax!
const squares = [ ... seq.range(10) |> seq.map(x => x * x) ];Dependencies are managed by Yarn:
yarn install --pure-lockfileTo run all tests:
yarn testTo build the library:
yarn buildTo build the documentation:
yarn docsTo release a new version:
npm publish --access public