Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/zenparsing/zen-observable
An Implementation of Observables for Javascript
https://github.com/zenparsing/zen-observable
Last synced: about 20 hours ago
JSON representation
An Implementation of Observables for Javascript
- Host: GitHub
- URL: https://github.com/zenparsing/zen-observable
- Owner: zenparsing
- License: mit
- Created: 2015-09-01T05:35:20.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2023-01-04T21:36:34.000Z (about 2 years ago)
- Last Synced: 2025-01-18T01:00:20.762Z (8 days ago)
- Language: JavaScript
- Homepage:
- Size: 490 KB
- Stars: 886
- Watchers: 16
- Forks: 44
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-crafted-nodejs - zen-observable - An Implementation of Observables for Javascript (Packages / Others)
- awesome - zen-observable - An Implementation of Observables for Javascript (JavaScript)
- awesome-nodejs-cn - zen-observable - Observables 的实现 (包 / 流程控制)
- awesome-nodejs - zen-observable - Implementation of Observables. ![](https://img.shields.io/github/stars/zenparsing/zen-observable.svg?style=social&label=Star) (Repository / Control flow)
- awesome-nodejs - zen-observable - An Implementation of Observables for Javascript - ★ 457 (Control flow)
- awesome-node - zen-observable - Implementation of Observables. (Packages / Control flow)
- awesome-nodejs-cn - zen-observable - 观察者模式实现. (目录 / 流程控制)
README
# zen-observable
An implementation of Observables for JavaScript. Requires Promises or a Promise polyfill.
## Install
```sh
npm install zen-observable
```## Usage
```js
import Observable from 'zen-observable';Observable.of(1, 2, 3).subscribe(x => console.log(x));
```## API
### new Observable(subscribe)
```js
let observable = new Observable(observer => {
// Emit a single value after 1 second
let timer = setTimeout(() => {
observer.next('hello');
observer.complete();
}, 1000);// On unsubscription, cancel the timer
return () => clearTimeout(timer);
});
```Creates a new Observable object using the specified subscriber function. The subscriber function is called whenever the `subscribe` method of the observable object is invoked. The subscriber function is passed an *observer* object which has the following methods:
- `next(value)` Sends the next value in the sequence.
- `error(exception)` Terminates the sequence with an exception.
- `complete()` Terminates the sequence successfully.
- `closed` A boolean property whose value is `true` if the observer's subscription is closed.The subscriber function can optionally return either a cleanup function or a subscription object. If it returns a cleanup function, that function will be called when the subscription has closed. If it returns a subscription object, then the subscription's `unsubscribe` method will be invoked when the subscription has closed.
### Observable.of(...items)
```js
// Logs 1, 2, 3
Observable.of(1, 2, 3).subscribe(x => {
console.log(x);
});
```Returns an observable which will emit each supplied argument.
### Observable.from(value)
```js
let list = [1, 2, 3];// Iterate over an object
Observable.from(list).subscribe(x => {
console.log(x);
});
``````js
// Convert something 'observable' to an Observable instance
Observable.from(otherObservable).subscribe(x => {
console.log(x);
});
```Converts `value` to an Observable.
- If `value` is an implementation of Observable, then it is converted to an instance of Observable as defined by this library.
- Otherwise, it is converted to an Observable which synchronously iterates over `value`.### observable.subscribe([observer])
```js
let subscription = observable.subscribe({
next(x) { console.log(x) },
error(err) { console.log(`Finished with error: ${ err }`) },
complete() { console.log('Finished') }
});
```Subscribes to the observable. Observer objects may have any of the following methods:
- `next(value)` Receives the next value of the sequence.
- `error(exception)` Receives the terminating error of the sequence.
- `complete()` Called when the stream has completed successfully.Returns a subscription object that can be used to cancel the stream.
### observable.subscribe(nextCallback[, errorCallback, completeCallback])
```js
let subscription = observable.subscribe(
x => console.log(x),
err => console.log(`Finished with error: ${ err }`),
() => console.log('Finished')
);
```Subscribes to the observable with callback functions. Returns a subscription object that can be used to cancel the stream.
### observable.forEach(callback)
```js
observable.forEach(x => {
console.log(`Received value: ${ x }`);
}).then(() => {
console.log('Finished successfully')
}).catch(err => {
console.log(`Finished with error: ${ err }`);
})
```Subscribes to the observable and returns a Promise for the completion value of the stream. The `callback` argument is called once for each value in the stream.
### observable.filter(callback)
```js
Observable.of(1, 2, 3).filter(value => {
return value > 2;
}).subscribe(value => {
console.log(value);
});
// 3
```Returns a new Observable that emits all values which pass the test implemented by the `callback` argument.
### observable.map(callback)
Returns a new Observable that emits the results of calling the `callback` argument for every value in the stream.
```js
Observable.of(1, 2, 3).map(value => {
return value * 2;
}).subscribe(value => {
console.log(value);
});
// 2
// 4
// 6
```### observable.reduce(callback [,initialValue])
```js
Observable.of(0, 1, 2, 3, 4).reduce((previousValue, currentValue) => {
return previousValue + currentValue;
}).subscribe(result => {
console.log(result);
});
// 10
```Returns a new Observable that applies a function against an accumulator and each value of the stream to reduce it to a single value.
### observable.concat(...sources)
```js
Observable.of(1, 2, 3).concat(
Observable.of(4, 5, 6),
Observable.of(7, 8, 9)
).subscribe(result => {
console.log(result);
});
// 1, 2, 3, 4, 5, 6, 7, 8, 9
```Merges the current observable with additional observables.
### observable.all()
```js
let observable = Observable.of(1, 2, 3);
for (let value of await observable.all()) {
console.log(value);
}
// 1, 2, 3
```Returns a `Promise` for an array containing all of the values produced by the observable.