React & Redux

Modern UI libraries

Madhan Ganesh

Agenda

Component

Rendering Logic

Multiplatform

Redux

Meet React

A Javascript library for building user interfaces

Meet React

Renders your UI and responds to

events 

Meet React

AKA: The V in MVC

Meet React

Can work with plain JavaScript models

Meet React

React enables Component

based UI

Meet React

Plays nicely with your stack,

whatever it maybe 

Meet React Component

JSX

A syntax extension to JavaScript

JSX

A syntax extension to JavaScript

React Component

A highly cohesive building block UIs loosely coupled with other components

class TodoApp extends React.Component {
  constructor(props) {
    super(props);
    this.handleChange = this.handleChange.bind(this);
    this.handleSubmit = this.handleSubmit.bind(this);
    this.state = {items: [], text: ''};
  }

  render() {
    return (
      <div>
        <h3>TODO</h3>
        <TodoList items={this.state.items} />
        <form onSubmit={this.handleSubmit}>
          <input onChange={this.handleChange} value={this.state.text} />
          <button>{'Add #' + (this.state.items.length + 1)}</button>
        </form>
      </div>
    );
  }

  handleChange(e) {
    this.setState({text: e.target.value});
  }

  handleSubmit(e) {
    e.preventDefault();
    var newItem = {
      text: this.state.text,
      id: Date.now()
    };
    this.setState((prevState) => ({
      items: prevState.items.concat(newItem),
      text: ''
    }));
  }
}

ReactDOM.render(<TodoApp />, mountNode);
class TodoList extends React.Component {
  render() {
    return (
      <ul>
        {this.props.items.map(item => (
          <li key={item.id}>{item.text}</li>
        ))}
      </ul>
    );
  }
}

Abstraction

Composition

Expressive

Components are reusable

Components are composable

Components are unit testable

Components are small

Components has only display logic

const React = require('react');

class ActionButton implements React.Component {
    
    render() {
        return (
            <button class="ActionButton" onClick={this.props.onAction}>
                <span>{this.props.text}</span>
            </button>
        )
    }

}

Props & Actions

<ActionButton text="Book flight" onAction={someFunc} />

State

class Timer extends React.Component {
  constructor(props) {
    super(props);
    this.state = {secondsElapsed: 0};
  }

  tick() {
    this.setState((prevState) => ({
      secondsElapsed: prevState.secondsElapsed + 1
    }));
  }

  componentDidMount() {
    this.interval = setInterval(() => this.tick(), 1000);
  }

  componentWillUnmount() {
    clearInterval(this.interval);
  }

  render() {
    return (
      <div>Seconds Elapsed: {this.state.secondsElapsed}</div>
    );
  }
}
<Timer />

State used in render

Initial State

State Updated

Component Props & States

React Component

Properties

Actions

 

State

 

render()

Breaking the monolith

React Styling

class Card extends Component {

    render() {

        const style = {
            height: '200',
            width: '150'
        };
        
        return (
            <div style={style}>
            </div>
        );

    }

}

Rendering Logic

Re-render the whole app on every update

The key design decision that makes React awesome

Building UIs is hard because there is so much state

Process vs State

Following processes is difficult programming model

vs

Programming snap-shot of state

DOM

The main problem is that DOM was never optimized for creating dynamic UI.

When.

When the data is changed and needed to be updated. But how do we know that the data is changed?

Dirty Checking

poll the data at a regular interval and check all of the values in the data structure recursively.

Observable

observe for the state change. If nothing has changed, we do nothing. If it changed, we know exactly what to update.

Virtual DOM

The Virtual DOM is an abstraction of the HTML DOM. It is lightweight and detached from the browser-specific implementation details.

 

Knockout

Angular

React

Observable

Dirty Checking

Virtual DOM

Virtual DOM

Benchmarks

https://auth0.com/blog/more-benchmarks-virtual-dom-vs-angular-12-vs-mithril-js-vs-the-rest/

Demo

https://jsfiddle.net/madhanganesh/bujwyv18/

https://jsfiddle.net/madhanganesh/92edcx4p/

class MyComponent extends React.Component {

  constructor() {
    this.state = { blue: false, green: false }
  }
  
  onBlueClick() {
    this.setState({ blue: !this.state.blue });
  }
  
  onGreenClick() {
    this.setState({ green: !this.state.green });
  }
  
  render() {
    var blue = this.state.blue ? 'BLUE ON' : 'BLUE OFF';
    var green = this.state.green ? 'GREEN ON' : 'GREEN OFF';
    
    return (
      <div>
        <button onClick={this.onBlueClick}>Blue</button>
        <br/><br/>
        <button onClick={this.onGreenClick}>Green</button>
        
        <h4>{blue}</h4>
        <h4>{green}</h4>
      </div>
    )
  }
}
function MyController($scope) {
  $scope.showBlue = false;
  $scope.showGreen = false;
  
  $scope.onBlueClick = function() {
  	$scope.showBlue = !$scope.showBlue;
  }
  
  $scope.onGreenClick = function() {
  	$scope.showGreen = !$scope.showGreen;
  }  
}
<div ng-app>
  <div ng-controller="MyController">
    <button ng-click="onBlueClick()">Blue</button>
    <br /><br />
    <button ng-click="onGreenClick()">Green</button>
    
    <div ng-show="showBlue">
      <h4>BLUE ON</h4>
    </div>
    <div ng-hide="showBlue">
      <h4>BLUE OFF</h4>
    </div>
    <div ng-show="showGreen">
      <h4>GREEN ON</h4>
    </div>
    <div ng-hide="showGreen">
      <h4>GREEN OFF</h4>
    </div>
  </div>
</div>

Dirty Checking (Angular)

Virtual DOM (React)

Multiplatform

Learn once; write anywhere

Multiplatform

React Native (ios)

import React, { Component } from 'react';
import { AppRegistry, Text } from 'react-native';

class HelloWorldApp extends Component {

  render() {
    return (
      <Text>Hello world!</Text>
    );
  }

}

AppRegistry.registerComponent('HelloWorldApp', () => HelloWorldApp);

React is for UI and not webapps

Component

(Data)   =>   Element

UI Element

Redux

Architecture Pattern for

uni-directinal data flow

Uni-directional data flow

Initial Data

 

Realtime Updates

 

User Input

 

Dispatcher

 

Store

 

View

 

Traditional MVC

Redux

Datastore

var appState = {
  user: {
    name: 'madhan'
  },
  taskData: {
    filter: 'pending',
      tasks: [
        'task A',
        'task B'
      ]
  }
};

Read State

Action(s)

var action = {
  ACTION: 'SHOW_PENDING'
};
var action = {
  action: 'TASKS_LOADED',
  tasks: [
    ...
  ]
};

Fire Action

Reducer(s)

BE & FE State

function reducer(state = [], action) {
  switch (action.type) {
    case 'TASKS_LOADED':
      state = Object.assign({}
                , action.data);
      return state;

    default:
      return state;
  }
}

View(s)

React - Redux

App Root

Page

Page

CompG

CompB

CompC

CompD

CompE

CompF

CompA

CompH

React State Tree

BE & FE State

Connect

props

dispatch

Redux Advantages

Single Source of truth

Time travel debugging

Persist-able State

Hot reloading of data

State is read only

State is read only

Thank You!

React: UI Library

By Madhan Ganesh L

React: UI Library

  • 915