Book Image

React Components

By : Christopher Pitt
Book Image

React Components

By: Christopher Pitt

Overview of this book

The reader will learn how to use React and its component-based architecture in order to develop modern user interfaces. A new holistic way of thinking about UI development will establish throughout this book and the reader will discover the power of React components with many examples. After reading the book and following the example application, the reader has built a small to a mid-size application with React using a component based UI architecture. The book will take the reader through a journey to discover the benefits of component-based user interfaces over the classical MVC architecture. Throughout the book, the reader will develop a wide range of components and then bring them together to build a component-based UI. By the end of this book, readers would have learned several techniques to build powerful components and how the component-based development is beneficial over regular web development.
Table of Contents (17 chapters)
React Components
Credits
About the Author
About the Reviewer
www.PacktPub.com
Preface
Index

Flux


At this stage, we encounter the first design pattern (and the improvements we can make). Flux is a pattern proposed by Facebook that defines the flow of data in an interface.

Note

Flux is not a library, but Facebook has released a few tools that help implement the design pattern. You don't have to use those tools to implement Flux. To install it, run npm install --save flux in addition to the previous dependencies.

We implemented something very close to Flux, but our implementation is at a slight disadvantage. Our Backend class does too much. We call it directly to add and fetch pages. It emits events when new pages are added. It's tightly coupled with the components that use it.

So, we'd have a hard time replacing it with a new Backend class (unless the methods, events and return values were in the exact same format). We'd have a hard time using multiple data backends. We don't even really have unidirectional flow of data because we send and receive data from Backend.

Flux differs here...