GitXplorerGitXplorer
s

observables-with-streams

public
134 stars
11 forks
3 issues

Commits

List of commits on branch master.
Verified
f773f05373e2efc1cc0175ac9fef4a9c0b47e1fc

Doc correction

ssurma committed 2 years ago
Verified
9d5edacd0164b61aa9471ee08e6e73e2c07847fb

0.6.1

ssurma committed 4 years ago
Verified
d1f5d6907d81aeab1d999267c3d2c09f58d2c67b

Fix watermarks

ssurma committed 4 years ago
Verified
10720407e1610fb8a654f887d862992f64cacae2

Update deps

ssurma committed 4 years ago
Verified
f2a8d4f6f531f03c62740586392988a6f90c9c73

0.6.0

ssurma committed 4 years ago
Verified
74f94b05b723acb947eb404586a7574c14a4a37e

0.6.0-1

ssurma committed 4 years ago

README

The README file for this repository.

Observables with Streams

A library for observables built with WHATWG streams. This library is inspired by ReactiveX’s operators and implements a subset of them using streams.

npm install --save observables-with-streams

The goal of this library is to implement observables making as much use of the platform as possible and being highly tree-shakeable.

Example

<!DOCTYPE html>

<button id="dec">-</button>

<span id="counter">0</span>

<button id="inc">+</button>

<script type="module">
  import * as ows from "observables-with-streams";

  ows.merge(
    ows.fromEvent(
      document.querySelector("#dec")
      "click"
    ).pipeThrough(ows.map(() => -1)),
    ows.fromEvent(
      document.querySelector("#inc")
      "click"
    ).pipeThrough(ows.map(() => 1))
  )
    .pipeThrough(
      ows.scan((v0, v1) => v0 + v1, 0)
    )
    .pipeTo(
      ows.subscribe(
        v => document.querySelector("#counter").textContent = v
      )
    );
</script>

Documentation

The (somewhat lacking) documentation for this library is hosted at https://observables-with-streams.surma.technology

Caveats

While most browsers have partial support of streams in stable, this library makes heavy use of TransformStreams, which are currently not well supported. Until browsers catch up, I can recommend Mattias Buelens' web-streams-polyfill.

For a good primer about streams, read this blog post by Jake Archibald (he is aware the title hasn’t aged well).


License Apache 2.0