lazily
TypeScript icon, indicating that this package has built-in type declarations

2.0.5 • Public • Published

lazily

Implements common array methods in a lazy manner. Nothing more.

There's an asynchronous version of this library as well, called lazily-async. See https://github.com/isotropy/lazily-async

Installation

npm install lazily

Create a sequence

import { Seq } from "lazily";

const seq = Seq.of([1, 2, 3])
for (const i of seq) {
  console.log(i)
}

It's lazy

Sequences are lazy. For example, in the following example only one map() action is performed irrespective of the length of the sequence.

const seq = Seq.of([1, 2, 3])
  .map(x => x * 2)
  .first();

toArray()

Seq.of([1, 2, 3])
  .toArray()
// [1, 2, 3]

map(fn)

Seq.of([1, 2, 3])
  .map(x => x * 2)
  .toArray()
// [2, 4, 6]

flatMap(fn)

Seq.of([1, 2, 3])
  .flatMap(x => [x*10, x*20])
  .toArray()
// [11, 21, 12, 22, 13, 23]

filter(predicate)

Seq.of([1, 2, 3, 4])
  .filter(x => x > 2)
  .toArray()
//[3, 4]

exit(predicate)

Seq.of([1, 2, 3, 4, 5])
  .exit(x => x > 3)
  .toArray()
// [1, 2, 3]

exitAfter(predicate)

Seq.of([1, 2, 3, 4, 5])
  .exitAfter(x => x > 3)
  .toArray()
// [1, 2, 3, 4]

find(predicate)

Seq.of([1, 2, 3, 4, 5])
  .find(x => x * 10 === 30)
// 3

reduce(fn)

Seq.of([1, 2, 3, 4, 5])
  .reduce((acc, x) => acc + x, 0)
// 15

short-circuited reduce(fn, initialValue, stopPredicate)

Seq.of([1, 2, 3, 4, 5])
  .reduce((acc, x) => acc + x, 0, acc => acc > 6)
// 10

first()

Seq.of([1, 2, 3, 4, 5])
  .first();
// 1

first(predicate)

Seq.of([1, 2, 3, 4, 5])
  .first(x => x > 3);
// 4

last()

Seq.of([1, 2, 3, 4, 5])
  .last();
// 5

last(predicate)

Seq.of([1, 2, 3, 4, 5])
  .last(x => x < 3);
// 2

every(predicate)

Seq.of([1, 2, 3, 4, 5])
  .every(x => x <= 5);
// true

some(predicate)

Seq.of([1, 2, 3, 4, 5])
  .some(x => x === 3);
// true

includes(item)

Seq.of([1, 2, 3, 4, 5])
  .includes(3);
// true

concat(seq)

Seq.of([1, 2, 3, 4, 5])
  .concat(Seq.of([6, 7, 8)]))
  .toArray();
// [1, 2, 3, 4, 5, 6, 7, 8]

reverse()

Seq.of([1, 2, 3, 4, 5])
  .reverse()
  .toArray();
// [5, 4, 3, 2, 1]

slice(begin, end)

Seq.of([1, 2, 3, 4, 5])
  .slice(2, 4)
  .toArray();
// [3, 4, 5]

Readme

Keywords

none

Package Sidebar

Install

npm i lazily

Weekly Downloads

3

Version

2.0.5

License

MIT

Unpacked Size

32.9 kB

Total Files

12

Last publish

Collaborators

  • jeswin