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
Universal Applications
Search
Stepan Parunashvili
March 19, 2016
Programming
0
80
Universal Applications
Building Universal Applications, Delivered at FE Day in Guangzhou
Stepan Parunashvili
March 19, 2016
Tweet
Share
More Decks by Stepan Parunashvili
See All by Stepan Parunashvili
Scaling React Applications
stopachka
2
100
Engineering Growth
stopachka
0
59
Universal Applications
stopachka
1
91
ES2015 & React
stopachka
0
61
ES2015
stopachka
0
64
Other Decks in Programming
See All in Programming
20260127_試行錯誤の結晶を1冊に。著者が解説 先輩データサイエンティストからの指南書 / author's_commentary_ds_instructions_guide
nash_efp
0
890
AIエージェントの設計で注意するべきポイント6選
har1101
7
3.4k
15年続くIoTサービスのSREエンジニアが挑む分散トレーシング導入
melonps
2
170
Automatic Grammar Agreementと Markdown Extended Attributes について
kishikawakatsumi
0
180
フルサイクルエンジニアリングをAI Agentで全自動化したい 〜構想と現在地〜
kamina_zzz
0
400
例外処理とどう使い分ける?Result型を使ったエラー設計 #burikaigi
kajitack
16
6k
QAフローを最適化し、品質水準を満たしながらリリースまでの期間を最短化する #RSGT2026
shibayu36
2
4.3k
カスタマーサクセス業務を変革したヘルススコアの実現と学び
_hummer0724
0
600
副作用をどこに置くか問題:オブジェクト指向で整理する設計判断ツリー
koxya
1
590
AI によるインシデント初動調査の自動化を行う AI インシデントコマンダーを作った話
azukiazusa1
1
680
React 19でつくる「気持ちいいUI」- 楽観的UIのすすめ
himorishige
11
5.9k
Honoを使ったリモートMCPサーバでAIツールとの連携を加速させる!
tosuri13
1
170
Featured
See All Featured
How to make the Groovebox
asonas
2
1.9k
A better future with KSS
kneath
240
18k
Mozcon NYC 2025: Stop Losing SEO Traffic
samtorres
0
140
Ecommerce SEO: The Keys for Success Now & Beyond - #SERPConf2024
aleyda
1
1.8k
Producing Creativity
orderedlist
PRO
348
40k
The Anti-SEO Checklist Checklist. Pubcon Cyber Week
ryanjones
0
55
Are puppies a ranking factor?
jonoalderson
1
2.7k
Everyday Curiosity
cassininazir
0
130
What Being in a Rock Band Can Teach Us About Real World SEO
427marketing
0
170
Become a Pro
speakerdeck
PRO
31
5.8k
Balancing Empowerment & Direction
lara
5
880
Designing for Timeless Needs
cassininazir
0
130
Transcript
Universal Applications Stepan Parunashvili 1
@stopachka www.stepanp.com 2 笳茯
Universal Applications 3
Isomorphic? 4
5
6
7
Isomorphic 8
Universal 9
10
...2015 11
...2014 12
...2013 13
...2012 14
...2011 15
...2010 16
...2009 17
2008 18
19
20 v2.2.2
21
22
23 javascript?
24 鉖᯾牦
25
26 routing validation views
27 routing validation views c00l animations
28 routing validation views c00l animations (in some browsers...b^.^d)
29
30
2009... 31
2010 32
33
34 v0.1.0
35
36
37
38
39 routing validation views
40 ...routing ...validation ...views routing validation views
41
42
43
is it just the way things are? 44
45
46
47 routing validation views
48
49 what if we made our own representation of the
dom...
...React! 50
win 1: code sharing 51
win 2: perceived performance 52
win 3: SEO 53
Can we build this? 54
ٵ॓ԧ牫 55
56 server.js
57 server.js
58 server.js
59 server.js
60
61
62 server.js
63 server.js
64 server.js
65
Time to react 66
67 components.js
68 server.js
69 server.js
70 server.js
71 server.js
72
73 components.js
74 components.js
75 components.js
76
77 server.js
78 server.js
79 server.js
80 load client side react client.js
81
...Now the views are shared 82
What's the catch? 83
build tools (webpack, babel & family) 84
Time to route 85
86 client.js
ReactRouter 87
88 server.js
let's disable universal rendering for now 89
90 server.js
91 server.js
92 components.js
93 load client side react components.js
94 load client side react routes.js
95 load client side react client.js
96 load client side react client.js
show it working 97
98
99
disable js 100
101 server.js
102 server.js server.js
103 server.js server.js
104 server.js server.js
105 server.js server.js
show it working 106
How about stores? 107
108 client.js
109 client.js
110 client.js
111 client.js
112 client.js
113 client.js
114 server.js server.js
115 server.js server.js
116 server.js server.js
initial data 珌牫 117
118 client.js
119 client.js
120 server.js
121 server.js
122 server.js
123 server.js
124 server.js
125 server.js
ok, ok....ݢฎ... 126
How about data fetching? 127
128 api.js
129 api.js
130 components.js
131 components.js
132 server.js
133 server.js
134 server.js
135 server.js
/home -> /page/2 ? 136
137 client.js
138 client.js
139 client.js
...but there's a library for that 140
react-resolver 141
is it all rosy? 142
not really 143
but the payoff? 144
145
146
147
148 routing validation views
wait... single-threaded-backend? 149
ClojureScript. 150
ClojureScript. Boom 151
so.. 152
Build Declaratively 153
Question assumptions 154
Questions? 155