This is the CFP for my React Rally talk, which was eventually accepted and given here: https://www.youtube.com/watch?v=nyFHR0dDZo0.
If you are a first time speaker, my CFP advice for new speakers is here.
Functional-reactive libraries like RxJS make it easy to understand how data changes, giving us tools to declaratively handle events and manage state. But while our render methods react to state changes, React isn’t reactive. Instead, we write imperative event-handlers, and trip up on gotchas like async setState and race conditions. Why? In this talk we build a Reactive React to show the difference between the "push" and "pull" paradigms of data flow and understand why React chooses to manage Scheduling as a core Design Principle, enabling awesome features like async rendering and Suspense!
Theme: This talk is a deep dive into React's core design principle around scheduling. Instead of abstract discussion, we make it accessible and real by exploring an alternate universe in which React was an FRP library and actually running into the problems React solves.
Optional theme song: Cinderella - Don't Know What You Got (Til It's Gone)
We follow a three-act structure where we:
- start off in an alternate universe where the prototype Reactive React I have built -is- the current React version,
- and then talk about why we might want interoperability with imperative libraries and more control over scheduling to do things like batching and async rendering,
- in order to propose switching Reactive React from a "push" based Functional Reactive Programming paradigm to a "pull" based approach where computations can be delayed until necessary.
In other words, we use a "what-if" scenario to better understand and appreciate the Design Principles behind React!
Outline:
- Recapping Reactive React
- A gentle introduction to Functional Reactive Programming
- Your UI as a stream
- Building a basic Reactive Component Class and reconciler
- Demonstrating usage to solve race conditions and other event streams
- Problems with Reactive React
- Poor interoperability with imperative libraries
- example with d3js
- Lack of control over scheduling
- too easy for the user to accidentally lock up the screen
- async rendering eg time slicing work would be all in userland
- Poor interoperability with imperative libraries
- A "pull" based React
- the Pull vs Push data flow paradigms
- exploring what the "pull" paradigm brings side by side with our prior examples
- interop with imperative libraries
- async rendering example: time slicing
- Proposing a complete rewrite of Reactive React ;)
This talk was born out of my frustration at why it felt so unnatural to connect RxJS with React even though I intuited that they embody superficially similar paradigms: ultimately, stuff happens, state changes, and then the dom changes because the state changes. I was also inspired by Paul O Shannessy's React Rally 2016 talk where he showed it was possible to "build react from scratch" and show all the key parts in a single talk. So I tried building a reactive version of React, and to my surprise, it wasn't hard. So it begged the question: why -isn't- React reactive?
And that is how I discovered the Scheduling section of React's Design Principles, where they explicitly joke that React should have been called "Schedule" because React does not want to be fully "reactive". The React team already thought about this, and I had NO IDEA.
I think a lot of React developers (like myself) often take the way things are for granted, and don't spend a lot of time understanding the reasons behind API choices and Design Principles like why React wants control over scheduling. This is why non obvious questions pop up like this RFClarification: why is setState
asynchronous. So maybe the best way to do it is explore the alternate universe and actually run head on into the issues that React's Design Principles solve.
I found this rabbit hole fascinating and I think others will too. By better understanding React's design principles, the React community can, on a philosophical level, 1) better understand how React works, 2) better design the broader React ecosystem to work with core React, and 3) better engage with the React core team when doing open source contributions.
https://www.youtube.com/watch?v=GWCcZ6fnpn4
ReactNYC - Contributing To React (added by Dan Abramov to https://reactjs.org/docs/how-to-contribute.html#introductory-video)
https://www.youtube.com/watch?v=rPuwZJEA-9U
ReactNYC - Never Bundle React Again (lightning talk with some ideas on bundling)
https://www.youtube.com/watch?v=R6pSelWatP0
ReactNYC - React Suspense: The Interactive Experience (livestream link on Mar 28 - the edited video will be up after CFP submission deadline)