Introduction
Clear examples, explanations, and resources for RxJS.
By @btroncone
Introduction
RxJS is one of the hottest libraries in web development today. Offering a powerful, functional approach for dealing with events and with integration points into a growing number of frameworks, libraries, and utilities, the case for learning Rx has never been more appealing. Couple this with the ability to utilize your knowledge across nearly any language, having a solid grasp on reactive programming and what it can offer seems like a no-brainer.
But...
Learning RxJS and reactive programming is hard. There's the multitude of concepts, large API surface, and fundamental shift in mindset from an imperative to declarative style. This site focuses on making these concepts approachable, the examples clear and easy to explore, and features references throughout to the best RxJS related material on the web. The goal is to supplement the official docs and pre-existing learning material while offering a new, fresh perspective to clear any hurdles and tackle the pain points. Learning Rx may be difficult but it is certainly worth the effort!
Brand New to RxJS?
Start getting familiar with all the key concepts needed to be productive with our RxJS Primer!
Content
Operators
Operators are the horse-power behind observables, providing an elegant, declarative solution to complex asynchronous tasks. This section contains all RxJS operators, included with clear, executable examples. Links to additional resources and recipes for each operator are also provided, when applicable.
Operator Categories
OR...
Complete listing in alphabetical order
Understanding Subjects
A Subject is a special type of Observable which shares a single execution path among observers.
Concepts
Without a solid base knowledge of how Observables work behind the scenes, it's easy for much of RxJS to feel like 'magic'. This section helps solidify the major concepts needed to feel comfortable with reactive programming and Observables.
- RxJS Primer
- Get started transforming streams with map, pluck, and mapTo
- Time based operators comparison
- RxJS v5 -> v6 Upgrade
Recipes
Recipes for common use-cases and interesting solutions with RxJS.
- Alphabet Invasion Game
- Battleship Game
- Breakout Game
- Car Racing Game
- Catch The Dot Game
- Click Ninja Game
- Flappy Bird Game
- Game Loop
- Horizontal Scroll Indicator
- HTTP Polling
- Lockscreen
- Matrix Digital Rain
- Memory Game
- Mine Sweeper Game
- Platform Jumper Game
- Progress Bar
- Save Indicator
- Smart Counter
- Stop Watch
- Space Invaders Game
- Swipe To Refresh
- Tank Battle Game
- Tetris Game
- Type Ahead
- Uncover Image Game
Introductory Resources
New to RxJS and reactive programming? In addition to the content found on this site, these excellent resources will help jump start your learning experience!
Conferences
- RxJS Live - RxJS specific conference
Reading
-
RxJS Introduction - Official Docs
-
The Introduction to Reactive Programming You've Been Missing - André Staltz
-
RxJS: Observables, Observers and Operators Introduction - Todd Motto
Videos
-
Ultimate RxJS 💵 - Brian Troncone
-
Asynchronous Programming: The End of The Loop - Jafar Husain
-
What is RxJS? - Ben Lesh
-
Creating Observable from Scratch - Ben Lesh
-
Introduction to RxJS Marble Testing 💵 - Brian Troncone
-
Introduction to Reactive Programming 💵 - André Staltz
-
Reactive Programming using Observables - Jeremy Lund
Exercises
- Functional Programming in JavaScript - Jafar Husain
Tools
-
Rx Marbles - Interactive diagrams of Rx Observables - André Staltz
-
Rx Visualizer - Animated playground for Rx Observables - Misha Moroshko
-
Reactive.how - Animated cards to learn Reactive Programming - Cédric Soulas
-
Rx Visualization - Visualizes programming with RxJS - Mojtaba Zarei
Interested in RxJS 4? Check out Denis Stoyanov's excellent eBook!
Translations
A Note On References
All references included in this GitBook are resources, both free and paid, that helped me tremendously while learning RxJS. If you come across an article or video that you think should be included, please use the edit this page link in the top menu and submit a pull request. Your feedback is appreciated!