What are the differentiating features between Highland.js, Kefir.js, and Rx.js?
Asked Answered
P

2

12

Since subjective answers are to be avoided on SO, I'm specifically asking: What are the functional and/or performance differences between these three functional/reactive libraries that would make me choose one of them over the others? I have eliminated BaconJS because of its dependency on jQuery. I'm new to the JS streams, and primarily interested in starting to familiarize myself with them first in NodeJS, and later in AngularJS context. If you have selected one of these over the others, what criteria lead to the choice?

Pretypify answered 18/10, 2015 at 0:53 Comment(0)
C
18

Everything below is pretty subjective:)

RxJS

Pros:

  • Documentation and big community.
  • Shared interface with Rx* family. It's a big advantage because you can adopt samples from RxJava community.
  • A lot of primitives in the library and some samples how to use them
  • back-pressure
  • it is a kind of etalon for other libraries

Cons:

  • Sometimes it looks overcomplicated
  • Implemented with "Java" in mind

Bacon.js

Pros

  • Really nice documentation with some advanced samples(snake game, implementation for example)
  • a lot of primitives
  • Implemented with JS in mind
  • I found it really easy to start

Cons - it doesn't implement back-pressure which makes it silly on backend

Highland.js

Pros:

  • it's intended to work with node.js(or browserify) environment which is really nice
  • no alien concepts(from JavaScript/Node perspective)
  • back-pressure
  • the implementation is on top of Node streams which is really great idea
  • small footprint

Cons:

  • Silly documentation and no examples. Actually every time I'm trying to adopt samples from Rx or Bacon
  • absence of some primitives. Actually you can implement most of them by yourself already implemented but it's painful(see previous point)

Summary: because absence of samples you will learn them all:) IMHO, the most perspective one is Highland.js. But RxJs is much more mature

Tip: If you need to ask something on StackOverflow use RxJS dialect and translate it to youth

Compelling answered 25/11, 2015 at 22:32 Comment(1)
Thanks for the answer.. this is very much what I was looking for ("pros/cons"). Highland.js looks perhaps the most attractive based on what you wrote above. However, as I'm exploring React, a sample exists to use RxJS for the data flow instead of Flux. There's also Rx bindings for React, and an example for combining React, RxJS, React-router, and Webpack. So you're right, I'll likely end up learning more than one of them. :)Pretypify
R
5

The Reactive-Extensions repository has pages comparing these (each of the other ones to RxJS, naturally).

Bacon.js (and kefir.js as well)

Highland.js

Requiescat answered 18/10, 2015 at 1:20 Comment(1)
Thanks for pointing those out; I'll read through them. I keep this question open still for a while in case someone has done an in-depth comparison between them.Pretypify

© 2022 - 2024 — McMap. All rights reserved.