background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data...

49

Transcript of background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data...

Page 1: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift
Page 2: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

@bluecrowbar

Steven Vandeweghe iOS developer

Page 3: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

background…

Page 4: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

By JavaScript,Pixabay - pixabay.com, CC BY 4.0, https://commons.wikimedia.org/w/index.php?curid=49984167

Page 5: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift
Page 6: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

never used

Page 7: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

not on

Page 8: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

reality distortion field

🤕

Page 9: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

time tracking app

Page 10: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

web macOS

iOS Android

Page 11: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

web first

Page 12: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

why React?

Page 13: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

“learn once, write anywhere”

Page 14: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

“a javascript library for building user interfaces”

Page 15: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

I get it

Page 16: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

the basics…

Page 17: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

components

Page 18: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

render()

Page 19: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

JSX

Page 20: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

mount

Page 21: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

data

external → this.props internal → this.state

Page 22: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

props

Page 23: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

state

Page 24: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

efficient?

Page 25: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

efficient?

virtual DOM

Page 26: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

lifecycle functions

Page 27: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

render getInitialState

getDefaultProps propTypes

componentWillMount componentDidMount

componentWillUnmount shouldComponentUpdate

Page 28: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

data?

Page 29: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

unidirectional data flow

Image from Flux by Facebook

Page 30: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift
Page 31: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

“you might not need Redux”

— Dan Abramov

https://medium.com/@dan_abramov/you-might-not-need-redux-be46360cf367#.4ea7e61oo

Page 32: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

Single source of truth

Page 33: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

State is read-only

Page 34: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

Changes are made with pure functions

(reducers)

Page 35: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift
Page 36: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift
Page 37: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

demo

Page 38: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

tools

Page 39: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift
Page 40: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift
Page 41: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift
Page 42: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift
Page 43: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift
Page 44: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift
Page 45: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift
Page 46: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift
Page 47: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift
Page 48: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

Thanks!

Page 49: background…files.meetup.com/9951662/React-StevenVandeweghe-September201… · Unidirectional Data Flow in sw x C https:// realm.io Inews/benji-encz-unidirectional-data-flow-swift

timeframeapp.com