Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
I Hated React too Soon, Reconciled with It Quic...
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Tugberk Ugurlu
January 20, 2017
Programming
100
0
Share
I Hated React too Soon, Reconciled with It Quickly Afterwards
NDC London 2017 (London, UK)
Tugberk Ugurlu
January 20, 2017
More Decks by Tugberk Ugurlu
See All by Tugberk Ugurlu
Redis Cluster for Write Intensive Workloads
tourismgeek
1
21k
Designing Towards Event Sourcing
tourismgeek
1
20k
Essentials for Building and Leading Highly Effective Development Teams
tourismgeek
0
600
Let the Uncertainty be Your Friend: Finding Your Path in a Wiggly Road
tourismgeek
0
670
Benefits of Managed Kubernetes in Azure (Azure Container Service, AKS)
tourismgeek
0
600
Levelling up to Become a Technical Lead
tourismgeek
2
28k
Benefits of Managed Kubernetes in Azure (Azure Container Service, AKS)
tourismgeek
0
270
GraphQL
tourismgeek
0
270
ASP.NET MVC 5 vs ASP.net Web API 2 vs ASP.NET Core MVC 1
tourismgeek
1
1.1k
Other Decks in Programming
See All in Programming
AI時代だからこそ「Bloc」を採用する価値があるのかもしれない
takuroabe
0
220
Migrations : C'est une question d'hygiène !
vinceamstoutz
0
880
RailsTokyo 2026#4: AI様があれば、 Hotwireの弱点は消えるか?
naofumi
4
510
AlarmKitで明後日起きれるアラームアプリを作る
trickart
0
140
Skillは並べた。動かなかった。契約で繋いだ。— 65個のSkillから、自走する開発サイクルへ
junholee
0
690
How We Practice Exploratory Testing in Iterative Development( #scrumniigata ) / 反復開発の中で、探索的テストをどう実施しているか
teyamagu
PRO
3
1.1k
20260514_its_the_context_window_stupid.pdf
heita
0
1.1k
ローカルLLMでどこまでコードが書けるか / How much code can be written on a local LLM
kishida
2
400
Stage 3 Decorators でできること / できないこと / TSKaigi 2026
susisu
1
410
「OSSがあるなら自作するな」は AI時代も正しいか ── Build vs Adopt の新しい判断基準
kumorn5s
7
2.9k
過去のレビュー知見をSkillsで資産化した話
pkshadeck
PRO
1
2.2k
Swiftのレキシカルスコープ管理
kntkymt
0
180
Featured
See All Featured
Exploring the relationship between traditional SERPs and Gen AI search
raygrieselhuber
PRO
2
4k
Practical Tips for Bootstrapping Information Extraction Pipelines
honnibal
25
1.9k
<Decoding/> the Language of Devs - We Love SEO 2024
nikkihalliwell
1
220
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
9
1.3k
Thoughts on Productivity
jonyablonski
76
5.2k
Neural Spatial Audio Processing for Sound Field Analysis and Control
skoyamalab
0
300
DevOps and Value Stream Thinking: Enabling flow, efficiency and business value
helenjbeal
1
190
JAMstack: Web Apps at Ludicrous Speed - All Things Open 2022
reverentgeek
1
450
Sam Torres - BigQuery for SEOs
techseoconnect
PRO
0
270
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
35
2.4k
Why You Should Never Use an ORM
jnunemaker
PRO
61
9.8k
Beyond borders and beyond the search box: How to win the global "messy middle" with AI-driven SEO
davidcarrasco
3
140
Transcript
I Hated React too Soon, Reconciled with It Quickly Afterwards
Tugberk Ugurlu Software Engineer @ Redgate @tourismgeek http://tugberkugurlu.com https://flic.kr/p/cQRAYC
https://flic.kr/p/e6nUW Aim of the Talk
https://flic.kr/p/t3H9A Once upon a time…
https://flic.kr/p/cEJMpW
https://flic.kr/p/faTRHU
https://flic.kr/p/7yqhJt JSX!
https://flic.kr/p/6sZ7Kp
https://twitter.com/tourismgeek/status/637380542191796224
https://twitter.com/tourismgeek/status/637380542191796224
None
https://flic.kr/p/6doME6
None
None
TODO: WHY! https://flic.kr/p/9yaos5
React is Simple Give it an input, get an output
React does one thing and it does it well It has a small public API surface area
https://twitter.com/thomasfuchs/status/708675139253174273
React is Simple “React applications start complex but maintenance complexity
of React applications doesn’t grow much as your applications grow
Its declarative and predictable nature High level of transferable knowledge
Learn once, write everywhere
React shines with Redux
What is Redux? “Redux is a state management library for
JavaScript applications, inspired by Flux and Elm.
What is Redux? (in human English) “Kind of like event
sourcing and pub/sub, with a fancier name.
The Problem
Redux Store
The Meat of Redux Actions Reducers Store
The Meat of Redux Actions Actions describe updates
The Meat of Redux Reducers Reducers apply updates based on
actions
The Meat of Redux Store Store is where everything comes
together and it acts as the source of truth for the application state
Simple Example: Counter
React Usage (Manual Way)
Usage with React
The Whole Idea Data Down Actions Up http://www.samselikoff.com/blog/data-down-actions-up/
The Whole Idea You have one state, one state only
for your entire application! https://flic.kr/p/9QQHW
The Whole Idea You never mutate the state! https://flic.kr/p/pzf72v
But why Redux and not flux, mobx, marty? https://flic.kr/p/NzcYg
It boils down to scientific reasons https://flic.kr/p/byrtr Well... NO!
Widely Adopted
Widely Adopted
Rich Docs and Resources http://redux.js.org/
Rich Ecosystem https://www.npmjs.com/search?q=redux
Rich Ecosystem http://redux-form.com/6.0.0-rc.5
Boost on Happiness with React and Redux https://flic.kr/p/99iZtS
https://twitter.com/dan_abramov/status/780475600716857344
https://github.com/facebook/react-devtools React Developer Tools
Redux Developer Tools https://github.com/gaearon/redux-devtools https://github.com/zalmoxisus/redux-devtools-extension
Redux Logger npm install redux-logger https://github.com/evgenyrodionov/redux-logger
Redux Immutable State Checker npm install redux-immutable-state-invariant https://github.com/leoasis/redux-immutable-state-invariant
Redux Undo npm install redux-undo https://github.com/omnidan/redux-undo
https://github.com/joshwcomeau/redux-vcr Redux VCR
https://twitter.com/tourismgeek/status/767629396916178947
https://egghead.io/courses/getting-started-with-redux Some Resources
https://egghead.io/courses/building-react-applications-with-idiomatic-redux Some Resources
Some Resources • My Blog Post on React: http://bit.ly/2jwicka •
React Docs: https://facebook.github.io/react/docs/hello-world.html • Redux Docs: http://redux.js.org • The Redux Journey at react-europe 2016: http://bit.ly/2bJEZEP • Redux Usage with React: http://bit.ly/2bdAiVO • Presentational and Container Components: http://bit.ly/2bM3DpO • (Pluralsight Course) Building Applications with React and Redux in ES6: http://bit.ly/2bRAQ4T • Thinking in React: https://facebook.github.io/react/docs/thinking-in-react.html • React Reconciliation: https://facebook.github.io/react/docs/reconciliation.html • Influencers of Redux: https://github.com/reactjs/redux#influences • Why did you reinvented Event Sourcing?: https://github.com/gaearon/ama/issues/110
99% Boost on Dev Happiness npm install redux-logger https://github.com/evgenyrodionov/redux-logger https://twitter.com/tourismgeek/status/637380542191796224
Redux Internals: It’s Freakin Tiny!