SlideShare a Scribd company logo
Pain and Joy of creating
isomorphic applications in
ReactJS
Viktor Turskyi
Kharkiv JS 2015
Isomorphism o_O
The interest of isomorphisms lies in the fact that two isomorphic objects cannot be
distinguished by using only the properties used to define morphisms; thus
isomorphic objects may be considered the same as long as one considers only
these properties and their consequences.
(Wikipedia)
Isomorphic application (simpler definition)
Just SPA that can be run on server
Demo (app in real life)
wall.itsquiz.com
Client
Server
Shared code REST
API
REST
API
Shared code
REST
API
View
Routing
Fetching I18N
Models
What for? (about joy)
Search engine optimization
Loading speed
Colors of isomorphic
1) Isomorphic view
2) Isomorphic styles
3) Isomorphic routing
4) Isomorphic data fetching
5) Isomorphic configuration
6) Isomorphic ES6
7) Isomorphic localization
Joy #1 - React
View - client
View - server
Pain #1 - cannot import styles in nodejs
Solution - inline styles (styles - just JSON)
Issues with inline styles
1) pseudo attributes :hover, :active, :focus
2) media queries
3) autoprefixing
4) styles merging
Kharkiv JS  2015 - Creating isomorphic applications in React (en)
Server and client renders different markup
Pain #2 - client side autoprefixer
Solution that just works
Choosing UI components library
Pain #3 - “Material UI” uses client side autoprefixer
We’ve switched to Material Design Lite
react-mdl (Material Design Lite) works great!!! )
What next?
Hooray, the problem with the styles is solved!!!
Not this time!!!
Pain #4 - assets loading order
How to do it right?
Load CSS at the beginning
Load Javascript at the end
Correct loading order
Solution - Text Extract Plugin for Webpack
Joy #2 - React Router
Routing (shared code)
Routing (client)
Routing (server)
Joy #3 - Redux
One store per application
Work with REST API
Data fetching steps
Client:
1. React component rendering
2. Show spinner
3. Fetch data
4. Update the page (rerender React component with fetched data)
Server:
1. Preload all required data for a page
2. Render the page to string
3. Send HTML to client
REST API - shared code (isomorphic-fetch)
What is left outside of the talk
1) Isomorphic configuration
2) Isomorphic localization
3) Isomorphic ES6
Statistics
Universal code - 1778 SLOC (93%)
Client specific code - 33 SLOC (2%)
Server specific code - 95 SLOC (5%)
links
Redux http://rackt.org/redux/index.html
React Router https://github.com/rackt/react-router
Tutorial: Handcrafting an Isomorphic Redux Application (With Love)
https://medium.com/@bananaoomarang/handcrafting-an-isomorphic-redux-
application-with-love-40ada4468af4
The application source code
https://github.com/WebbyLab/itsquiz-wall/
Viktor Turskyi (koorchik)
viktor@webbylab.com
https://twitter.com/koorchik
https://github.com/koorchik
http://webbylab.com

More Related Content

PDF
JS Lab 2016 - Frontend trends 2015 - 2016
PPTX
It's just Angular
PPTX
ASP.NET Core: The best of the new bits
PDF
Isomorphic web application
PPTX
ASP.NET Core MVC + Web API with Overview (Post RC2)
PPTX
ASP.NET Core MVC + Web API with Overview
PPTX
ASP.NET Core 1.0 Overview
PPTX
Evolution / History of ASP.NET
JS Lab 2016 - Frontend trends 2015 - 2016
It's just Angular
ASP.NET Core: The best of the new bits
Isomorphic web application
ASP.NET Core MVC + Web API with Overview (Post RC2)
ASP.NET Core MVC + Web API with Overview
ASP.NET Core 1.0 Overview
Evolution / History of ASP.NET

What's hot (20)

PDF
Getting Started with ASP.NET Core 1.0 (formerly ASP.NET 5)
PPTX
Moving forward with ASP.NET Core
PPTX
Getting Started with ASP.net Core 1.0
PPTX
The Saga of JavaScript and TypeScript: Part 1
PPTX
ASP.NET Core MVC + Web API with Overview
PPTX
.Net Core 1.0 vs .NET Framework
PDF
Moving ASP.NET MVC to ASP.NET Core
PDF
JSFoo-2017 Takeaways
PDF
AngularJS + React
PPTX
Introduction to .NET Core & ASP.NET Core MVC
PDF
TDD a REST API With Node.js and MongoDB
PPTX
ASP.NET 5 Overview: Post RTM
PDF
Introduction to ASP.NET Core
PPTX
Develop a Basic REST API from Scratch Using TDD with Val Karpov
PDF
An Intro to Angular 2
PPTX
From .NET Core 3, all the rest will be legacy
PPT
Next generation frontend tooling
PDF
Conquering AngularJS Limitations
PPTX
ASP.NET 5 Overview for Apex Systems
PDF
Angular 2 vs React
Getting Started with ASP.NET Core 1.0 (formerly ASP.NET 5)
Moving forward with ASP.NET Core
Getting Started with ASP.net Core 1.0
The Saga of JavaScript and TypeScript: Part 1
ASP.NET Core MVC + Web API with Overview
.Net Core 1.0 vs .NET Framework
Moving ASP.NET MVC to ASP.NET Core
JSFoo-2017 Takeaways
AngularJS + React
Introduction to .NET Core & ASP.NET Core MVC
TDD a REST API With Node.js and MongoDB
ASP.NET 5 Overview: Post RTM
Introduction to ASP.NET Core
Develop a Basic REST API from Scratch Using TDD with Val Karpov
An Intro to Angular 2
From .NET Core 3, all the rest will be legacy
Next generation frontend tooling
Conquering AngularJS Limitations
ASP.NET 5 Overview for Apex Systems
Angular 2 vs React
Ad

Viewers also liked (17)

PPTX
Monitoring of developers. The necessity or self-indulgence by Oleksiy Dyomin
PDF
GMS, IT-рекрутинговое агентство: о компании и услугах
PDF
Bluetest success story
PDF
лидогенерация для B2 b компаний в социальных сетях
PDF
Flavors of Concurrency in Java
PDF
Growth Hacking Marketing или фишки лидогенерации. Игорь Канзычаков на Digitrend.
PDF
semanticweb2015-ConfirmationOfParticipation
PPTX
Indepenedent Contractor Website Tutorial
PDF
SPSHOU - Upgrading and Migrating to SharePoint 2016 like a Pro
PPTX
Web-application I have always dreamt of by Victor Polischuk
PDF
Geek22.outreach рассылки по покупным базам в сегменте B2B
PPTX
Interactive Java Support to your tool -- The JShell API and Architecture
PPTX
Апгрейд и миграция на SharePoint 2016
PDF
300 sp 2017_celabraciones
PDF
STEMing Kids: One workshop at a time
PDF
SPS Utah 2016 - Unlock your big data with analytics and BI on Office 365
PDF
階層モデルの分散パラメータの事前分布について
Monitoring of developers. The necessity or self-indulgence by Oleksiy Dyomin
GMS, IT-рекрутинговое агентство: о компании и услугах
Bluetest success story
лидогенерация для B2 b компаний в социальных сетях
Flavors of Concurrency in Java
Growth Hacking Marketing или фишки лидогенерации. Игорь Канзычаков на Digitrend.
semanticweb2015-ConfirmationOfParticipation
Indepenedent Contractor Website Tutorial
SPSHOU - Upgrading and Migrating to SharePoint 2016 like a Pro
Web-application I have always dreamt of by Victor Polischuk
Geek22.outreach рассылки по покупным базам в сегменте B2B
Interactive Java Support to your tool -- The JShell API and Architecture
Апгрейд и миграция на SharePoint 2016
300 sp 2017_celabraciones
STEMing Kids: One workshop at a time
SPS Utah 2016 - Unlock your big data with analytics and BI on Office 365
階層モデルの分散パラメータの事前分布について
Ad

Similar to Kharkiv JS 2015 - Creating isomorphic applications in React (en) (20)

PDF
Performance and Scalability Art of Isomorphic React Applications
PDF
Matheus Marsiglio - Isomorphic React + Redux App
PPTX
Isomorphic JavaScript with Node, WebPack, and React
PDF
Review on React JS
PPTX
React.js
PPTX
Isomorphic JavaScript – future of the web
PDF
Javascript leverage: Isomorphic Applications by Luciano Colosio at Codemotion...
PDF
Back to the future: Isomorphic javascript applications
PDF
Isomorphic JavaScript: #DevBeat Master Class
PDF
FRONTEND DEVELOPMENT WITH REACT.JS
PPTX
React js
PDF
Web Development with Delphi and React - ITDevCon 2016
PPTX
Grokking TechTalk #16: React stack at lozi
PPTX
Isomorphic apps
PPTX
Isomorphic web apps with react
PDF
Isomorphic React Applications: Performance And Scalability
PDF
Isomorphic javascript - Uppsala.js #8
PDF
"The Grail: React based Isomorph apps framework" Эльдар Джафаров
PDF
Isomorphic React - What, When and Why ?
PPTX
Reactjs notes.pptx for web development- tutorial and theory
Performance and Scalability Art of Isomorphic React Applications
Matheus Marsiglio - Isomorphic React + Redux App
Isomorphic JavaScript with Node, WebPack, and React
Review on React JS
React.js
Isomorphic JavaScript – future of the web
Javascript leverage: Isomorphic Applications by Luciano Colosio at Codemotion...
Back to the future: Isomorphic javascript applications
Isomorphic JavaScript: #DevBeat Master Class
FRONTEND DEVELOPMENT WITH REACT.JS
React js
Web Development with Delphi and React - ITDevCon 2016
Grokking TechTalk #16: React stack at lozi
Isomorphic apps
Isomorphic web apps with react
Isomorphic React Applications: Performance And Scalability
Isomorphic javascript - Uppsala.js #8
"The Grail: React based Isomorph apps framework" Эльдар Джафаров
Isomorphic React - What, When and Why ?
Reactjs notes.pptx for web development- tutorial and theory

More from Viktor Turskyi (18)

PDF
How to create a high performance excel engine in java script
PDF
Livr 2.0 in JS - Vinnytsia.JS 2019
PDF
The working architecture of node js applications open tech week javascript ...
PDF
Yet another json rpc library (mole rpc)
PDF
KharkivJS 2018 Information Security Practice
PDF
"Offline mode for a mobile application, redux on server and a little bit abou...
PDF
The working architecture of NodeJs applications
PDF
Language Independent Validation Rules 2.0, Viktor Turskyi, talk at OSDN 2017
PDF
How to extract information from text with Semgrex
PDF
How to translate your Single Page Application - Webcamp 2016 (en)
PDF
It's Quiz - Cloud testing platform
PDF
Kharkiv JS 2015: Боль и радость создания изоморфных приложений на ReactJS (RU)
PDF
Language Independent Validation Rules (LIVR)
PDF
Hadoop webcamp 2015
PDF
Mapreduce in JavaScript
PDF
Excel in Javascript
PDF
Testing orm based code
ODP
Maybe you do not know that ...
How to create a high performance excel engine in java script
Livr 2.0 in JS - Vinnytsia.JS 2019
The working architecture of node js applications open tech week javascript ...
Yet another json rpc library (mole rpc)
KharkivJS 2018 Information Security Practice
"Offline mode for a mobile application, redux on server and a little bit abou...
The working architecture of NodeJs applications
Language Independent Validation Rules 2.0, Viktor Turskyi, talk at OSDN 2017
How to extract information from text with Semgrex
How to translate your Single Page Application - Webcamp 2016 (en)
It's Quiz - Cloud testing platform
Kharkiv JS 2015: Боль и радость создания изоморфных приложений на ReactJS (RU)
Language Independent Validation Rules (LIVR)
Hadoop webcamp 2015
Mapreduce in JavaScript
Excel in Javascript
Testing orm based code
Maybe you do not know that ...

Recently uploaded (20)

PPTX
20250228 LYD VKU AI Blended-Learning.pptx
PDF
Empathic Computing: Creating Shared Understanding
PDF
KodekX | Application Modernization Development
PDF
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
PDF
solutions_manual_-_materials___processing_in_manufacturing__demargo_.pdf
PPTX
Telecom Fraud Prevention Guide | Hyperlink InfoSystem
PPTX
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
PDF
madgavkar20181017ppt McKinsey Presentation.pdf
PPT
“AI and Expert System Decision Support & Business Intelligence Systems”
PDF
Dropbox Q2 2025 Financial Results & Investor Presentation
PDF
GamePlan Trading System Review: Professional Trader's Honest Take
PDF
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
PDF
Chapter 3 Spatial Domain Image Processing.pdf
PPTX
breach-and-attack-simulation-cybersecurity-india-chennai-defenderrabbit-2025....
PDF
The Rise and Fall of 3GPP – Time for a Sabbatical?
PDF
AI And Its Effect On The Evolving IT Sector In Australia - Elevate
PDF
cuic standard and advanced reporting.pdf
PDF
NewMind AI Weekly Chronicles - August'25 Week I
PPTX
Cloud computing and distributed systems.
PPTX
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
20250228 LYD VKU AI Blended-Learning.pptx
Empathic Computing: Creating Shared Understanding
KodekX | Application Modernization Development
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
solutions_manual_-_materials___processing_in_manufacturing__demargo_.pdf
Telecom Fraud Prevention Guide | Hyperlink InfoSystem
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
madgavkar20181017ppt McKinsey Presentation.pdf
“AI and Expert System Decision Support & Business Intelligence Systems”
Dropbox Q2 2025 Financial Results & Investor Presentation
GamePlan Trading System Review: Professional Trader's Honest Take
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
Chapter 3 Spatial Domain Image Processing.pdf
breach-and-attack-simulation-cybersecurity-india-chennai-defenderrabbit-2025....
The Rise and Fall of 3GPP – Time for a Sabbatical?
AI And Its Effect On The Evolving IT Sector In Australia - Elevate
cuic standard and advanced reporting.pdf
NewMind AI Weekly Chronicles - August'25 Week I
Cloud computing and distributed systems.
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx

Kharkiv JS 2015 - Creating isomorphic applications in React (en)