Universal apps lightning talk

Universal Apps: Architecture
for the Modern Web
Elyse Kolker Gordon
Twitter: @sfdrummerjs, Github: @elyseko
Director, Web Platforms, Vevo
Deep dive with
the book!
Topics
● Overview
● Why build it?
● Tools and Frameworks
● Challenges/Tradeoffs
Overview: What is a
Universal App?
Server-side rendered applications
Overview
User Request Fetch Data
JSONHTML
Single Page Application (SPA)
Overview
JSON
Fetch data
Why not both?
Overview
HTML & Server
State (JSON)
Fetch Data
Overview
User Request Fetch Data
JSON
JSON
Then the SPA cycle
Why build it?
#1 SEO
Getting your website (or cat video) to
rank the highest can make or break
your success as a business.
Why build it?
#2 Perceived
Performance
Users should think the site is fast. This
means showing content (not loading
spinners) as soon as possible.
Why build it?
Everything is JavaScript! Most of your
code will run on both the server and
the browser.
#3 Maintenance and
Developer benefits
Why build it?
How to build it?
Write code once, run it in two
environments (node & browser).
How to build it
Universal Libraries/Frameworks
How to build it
Out of the box solutions
How to build it
Serialize and Hydrate the Data
How to build it
{
user: {...},
cart: {...},
products: {...}
}
“{“user”:{...},”cart”:{...}”products”:{...}“
Create a
string from
the data
window.__INITIAL__STATE = {
user: {...},
cart: {...},
products: {...}
}
Serialize and Hydrate the Data
createApp(window.__INITIAL__STATE)
Serialize and Hydrate the Data
How to build it
HTML generated on the server.
Debugger set before
the app hydrates the
server state.
Challenges and
Tradeoffs
Competing envs
Challenges and Tradeoffs
● Set environment flags via
webpack
● Use a single source of truth
user session info
● Npm packages must be
isomorphicWhere’s the window object?
Performance
Challenges and Tradeoffs
Rendering hundreds of UI
elements can be slow
● Implement caching
● Render less items
● Use streams (node.js)
Testing
Challenges and Tradeoffs
There are always two states.
● Initial load: when the user first
comes to the app.
● SPA lifecycle: any user
interaction after initial load
Universal architecture adds complexity, but gives
you clear benefits for SEO and performance.
1 of 25

Recommended

JWC 2015 - Mobile apps development for Joomla! by
JWC 2015 - Mobile apps development for Joomla!JWC 2015 - Mobile apps development for Joomla!
JWC 2015 - Mobile apps development for Joomla!Extly Extensions - JoomGap
777 views29 slides
Visual Studio ❤ JavaScript by
Visual Studio ❤ JavaScriptVisual Studio ❤ JavaScript
Visual Studio ❤ JavaScriptRobert MacLean
9.9K views15 slides
Frontend 'vs' Backend Getting the Right Mix by
Frontend 'vs' Backend   Getting the Right MixFrontend 'vs' Backend   Getting the Right Mix
Frontend 'vs' Backend Getting the Right MixBob Paulin
8.9K views56 slides
Joomla as a mobile App backend - ideas, examples and experiences by
Joomla as a mobile App backend - ideas, examples and experiencesJoomla as a mobile App backend - ideas, examples and experiences
Joomla as a mobile App backend - ideas, examples and experiencesAndy_Gaskell
2.7K views62 slides
The Future of-the CMS (Twin Cities DrupalCamp 2015) by
The Future of-the CMS (Twin Cities DrupalCamp 2015)The Future of-the CMS (Twin Cities DrupalCamp 2015)
The Future of-the CMS (Twin Cities DrupalCamp 2015)Todd Ross Nienkerk
660 views75 slides
Web dev syllabus by
Web dev syllabusWeb dev syllabus
Web dev syllabusAdithcheshan
357 views7 slides

More Related Content

What's hot

Save your social energy with windows live by
Save your social energy with windows liveSave your social energy with windows live
Save your social energy with windows liveMohamad Iqbal
260 views4 slides
WordPress as a Headless CMS - Bronson Quick by
WordPress as a Headless CMS - Bronson QuickWordPress as a Headless CMS - Bronson Quick
WordPress as a Headless CMS - Bronson QuickWordCamp Sydney
5.2K views21 slides
The Ultimate WordPress Development Environment by
The Ultimate WordPress Development EnvironmentThe Ultimate WordPress Development Environment
The Ultimate WordPress Development EnvironmentMatt Geri
1.2K views36 slides
Advanced custom fields in Wordpress by
Advanced custom fields in WordpressAdvanced custom fields in Wordpress
Advanced custom fields in WordpressExove
224 views16 slides
State of the Word 2015, WordCamp US by
State of the Word 2015, WordCamp USState of the Word 2015, WordCamp US
State of the Word 2015, WordCamp USphotomatt
366.9K views120 slides

What's hot(20)

Save your social energy with windows live by Mohamad Iqbal
Save your social energy with windows liveSave your social energy with windows live
Save your social energy with windows live
Mohamad Iqbal260 views
WordPress as a Headless CMS - Bronson Quick by WordCamp Sydney
WordPress as a Headless CMS - Bronson QuickWordPress as a Headless CMS - Bronson Quick
WordPress as a Headless CMS - Bronson Quick
WordCamp Sydney5.2K views
The Ultimate WordPress Development Environment by Matt Geri
The Ultimate WordPress Development EnvironmentThe Ultimate WordPress Development Environment
The Ultimate WordPress Development Environment
Matt Geri1.2K views
Advanced custom fields in Wordpress by Exove
Advanced custom fields in WordpressAdvanced custom fields in Wordpress
Advanced custom fields in Wordpress
Exove224 views
State of the Word 2015, WordCamp US by photomatt
State of the Word 2015, WordCamp USState of the Word 2015, WordCamp US
State of the Word 2015, WordCamp US
photomatt366.9K views
Rise of the responsive single page application by Oren Shatken
Rise of the responsive single page applicationRise of the responsive single page application
Rise of the responsive single page application
Oren Shatken4.8K views
Better WordPress Theme Development Workflow by Rajeeb Banstola
Better WordPress Theme Development WorkflowBetter WordPress Theme Development Workflow
Better WordPress Theme Development Workflow
Rajeeb Banstola2.5K views
Single page application by Arthur Fung
Single page applicationSingle page application
Single page application
Arthur Fung915 views
Ppt full stack developer by SudhirVarpe1
Ppt full stack developerPpt full stack developer
Ppt full stack developer
SudhirVarpe19.6K views
Making sense of the front-end, for PHP developers by Lewiz
Making sense of the front-end, for PHP developersMaking sense of the front-end, for PHP developers
Making sense of the front-end, for PHP developers
Lewiz 85 views
Intro to Web Development from Bloc.io by Douglas Wright
Intro to Web Development from Bloc.ioIntro to Web Development from Bloc.io
Intro to Web Development from Bloc.io
Douglas Wright961 views
Web Development and Web Development technologies - Temitayo Fadojutimi by Temitayo Fadojutimi
Web Development and Web Development technologies - Temitayo FadojutimiWeb Development and Web Development technologies - Temitayo Fadojutimi
Web Development and Web Development technologies - Temitayo Fadojutimi
Getting to Done on the Command Line by All Things Open
Getting to Done on the Command LineGetting to Done on the Command Line
Getting to Done on the Command Line
All Things Open945 views
Zero cost serverless Real time web app by Barcamp Saigon
Zero cost serverless Real time web appZero cost serverless Real time web app
Zero cost serverless Real time web app
Barcamp Saigon3.1K views
What's This React Native Thing I Keep Hearing About? by Evan Stone
What's This React Native Thing I Keep Hearing About?What's This React Native Thing I Keep Hearing About?
What's This React Native Thing I Keep Hearing About?
Evan Stone691 views
WordPress Tallahassee Meetup: Turning WordPress Sites Into Web & Mobile Apps by Caldera Labs
WordPress Tallahassee Meetup: Turning WordPress Sites Into Web & Mobile AppsWordPress Tallahassee Meetup: Turning WordPress Sites Into Web & Mobile Apps
WordPress Tallahassee Meetup: Turning WordPress Sites Into Web & Mobile Apps
Caldera Labs3.5K views
Progressive Web Apps / GDG DevFest - Season 2016 by Abdelrahman Omran
Progressive Web Apps / GDG DevFest - Season 2016Progressive Web Apps / GDG DevFest - Season 2016
Progressive Web Apps / GDG DevFest - Season 2016
Abdelrahman Omran1.7K views

Similar to Universal apps lightning talk

LATEST_TRENDS_IN_WEBSITE_DEVELOPMENT.pptx by
LATEST_TRENDS_IN_WEBSITE_DEVELOPMENT.pptxLATEST_TRENDS_IN_WEBSITE_DEVELOPMENT.pptx
LATEST_TRENDS_IN_WEBSITE_DEVELOPMENT.pptxchitrachauhan21
50 views28 slides
LAMP is so yesterday, MEAN is so tomorrow! :) by
LAMP is so yesterday, MEAN is so tomorrow! :) LAMP is so yesterday, MEAN is so tomorrow! :)
LAMP is so yesterday, MEAN is so tomorrow! :) Sascha Sambale
9.8K views70 slides
Apache Flex and the imperfect Web by
Apache Flex and the imperfect WebApache Flex and the imperfect Web
Apache Flex and the imperfect Webmasuland
2.2K views22 slides
Front End Development | Introduction by
Front End Development | IntroductionFront End Development | Introduction
Front End Development | IntroductionJohnTaieb
10.5K views37 slides
Netbeans65 Osum Slides by
Netbeans65 Osum SlidesNetbeans65 Osum Slides
Netbeans65 Osum SlidesAbhishek Gupta
1K views39 slides
Tech Thursdays: Building Products by
Tech Thursdays: Building ProductsTech Thursdays: Building Products
Tech Thursdays: Building ProductsHayden Bleasel
733 views51 slides

Similar to Universal apps lightning talk (20)

LATEST_TRENDS_IN_WEBSITE_DEVELOPMENT.pptx by chitrachauhan21
LATEST_TRENDS_IN_WEBSITE_DEVELOPMENT.pptxLATEST_TRENDS_IN_WEBSITE_DEVELOPMENT.pptx
LATEST_TRENDS_IN_WEBSITE_DEVELOPMENT.pptx
chitrachauhan2150 views
LAMP is so yesterday, MEAN is so tomorrow! :) by Sascha Sambale
LAMP is so yesterday, MEAN is so tomorrow! :) LAMP is so yesterday, MEAN is so tomorrow! :)
LAMP is so yesterday, MEAN is so tomorrow! :)
Sascha Sambale9.8K views
Apache Flex and the imperfect Web by masuland
Apache Flex and the imperfect WebApache Flex and the imperfect Web
Apache Flex and the imperfect Web
masuland2.2K views
Front End Development | Introduction by JohnTaieb
Front End Development | IntroductionFront End Development | Introduction
Front End Development | Introduction
JohnTaieb10.5K views
Tech Thursdays: Building Products by Hayden Bleasel
Tech Thursdays: Building ProductsTech Thursdays: Building Products
Tech Thursdays: Building Products
Hayden Bleasel733 views
Cross-platform Desktop application with AngularJS and build with Node-webkit by Wittawas Wisarnkanchana
Cross-platform Desktop application with AngularJS and build with Node-webkitCross-platform Desktop application with AngularJS and build with Node-webkit
Cross-platform Desktop application with AngularJS and build with Node-webkit
AngularJS + NancyFx + MongoDB = The best trio for ultimate SPA by Bojan Velja... by Bojan Veljanovski
AngularJS + NancyFx + MongoDB = The best trio for ultimate SPA by Bojan Velja...AngularJS + NancyFx + MongoDB = The best trio for ultimate SPA by Bojan Velja...
AngularJS + NancyFx + MongoDB = The best trio for ultimate SPA by Bojan Velja...
Bojan Veljanovski8.5K views
Enterprise PHP (PHP London Conference 2008) by Ivo Jansch
Enterprise PHP (PHP London Conference 2008)Enterprise PHP (PHP London Conference 2008)
Enterprise PHP (PHP London Conference 2008)
Ivo Jansch7.4K views
Top 11 Front-End Web Development Tools To Consider in 2020 by Katy Slemon
 Top 11 Front-End Web Development Tools To Consider in 2020 Top 11 Front-End Web Development Tools To Consider in 2020
Top 11 Front-End Web Development Tools To Consider in 2020
Katy Slemon53 views
Web Development Workshop (Front End) by DSCIIITLucknow
Web Development Workshop (Front End)Web Development Workshop (Front End)
Web Development Workshop (Front End)
DSCIIITLucknow225 views
Isomorphic JavaScript: #DevBeat Master Class by Spike Brehm
Isomorphic JavaScript: #DevBeat Master ClassIsomorphic JavaScript: #DevBeat Master Class
Isomorphic JavaScript: #DevBeat Master Class
Spike Brehm24.1K views
Java EE 7 from an HTML5 Perspective, JavaLand 2015 by Edward Burns
Java EE 7 from an HTML5 Perspective, JavaLand 2015Java EE 7 from an HTML5 Perspective, JavaLand 2015
Java EE 7 from an HTML5 Perspective, JavaLand 2015
Edward Burns3.4K views

Recently uploaded

Stone Masonry and Brick Masonry.pdf by
Stone Masonry and Brick Masonry.pdfStone Masonry and Brick Masonry.pdf
Stone Masonry and Brick Masonry.pdfMohammed Abdullah Laskar
20 views6 slides
An approach of ontology and knowledge base for railway maintenance by
An approach of ontology and knowledge base for railway maintenanceAn approach of ontology and knowledge base for railway maintenance
An approach of ontology and knowledge base for railway maintenanceIJECEIAES
12 views14 slides
SEMI CONDUCTORS by
SEMI CONDUCTORSSEMI CONDUCTORS
SEMI CONDUCTORSpavaniaalla2005
20 views8 slides
DevOps-ITverse-2023-IIT-DU.pptx by
DevOps-ITverse-2023-IIT-DU.pptxDevOps-ITverse-2023-IIT-DU.pptx
DevOps-ITverse-2023-IIT-DU.pptxAnowar Hossain
8 views45 slides
Multi-objective distributed generation integration in radial distribution sy... by
Multi-objective distributed generation integration in radial  distribution sy...Multi-objective distributed generation integration in radial  distribution sy...
Multi-objective distributed generation integration in radial distribution sy...IJECEIAES
15 views14 slides
SWM L1-L14_drhasan (Part 1).pdf by
SWM L1-L14_drhasan (Part 1).pdfSWM L1-L14_drhasan (Part 1).pdf
SWM L1-L14_drhasan (Part 1).pdfMahmudHasan747870
48 views150 slides

Recently uploaded(20)

An approach of ontology and knowledge base for railway maintenance by IJECEIAES
An approach of ontology and knowledge base for railway maintenanceAn approach of ontology and knowledge base for railway maintenance
An approach of ontology and knowledge base for railway maintenance
IJECEIAES12 views
Multi-objective distributed generation integration in radial distribution sy... by IJECEIAES
Multi-objective distributed generation integration in radial  distribution sy...Multi-objective distributed generation integration in radial  distribution sy...
Multi-objective distributed generation integration in radial distribution sy...
IJECEIAES15 views
Informed search algorithms.pptx by Dr.Shweta
Informed search algorithms.pptxInformed search algorithms.pptx
Informed search algorithms.pptx
Dr.Shweta16 views
A multi-microcontroller-based hardware for deploying Tiny machine learning mo... by IJECEIAES
A multi-microcontroller-based hardware for deploying Tiny machine learning mo...A multi-microcontroller-based hardware for deploying Tiny machine learning mo...
A multi-microcontroller-based hardware for deploying Tiny machine learning mo...
IJECEIAES13 views
Design and analysis of a new undergraduate Computer Engineering degree – a me... by WaelBadawy6
Design and analysis of a new undergraduate Computer Engineering degree – a me...Design and analysis of a new undergraduate Computer Engineering degree – a me...
Design and analysis of a new undergraduate Computer Engineering degree – a me...
WaelBadawy656 views
Effect of deep chemical mixing columns on properties of surrounding soft clay... by AltinKaradagli
Effect of deep chemical mixing columns on properties of surrounding soft clay...Effect of deep chemical mixing columns on properties of surrounding soft clay...
Effect of deep chemical mixing columns on properties of surrounding soft clay...
AltinKaradagli6 views
Thermal aware task assignment for multicore processors using genetic algorithm by IJECEIAES
Thermal aware task assignment for multicore processors using genetic algorithm Thermal aware task assignment for multicore processors using genetic algorithm
Thermal aware task assignment for multicore processors using genetic algorithm
IJECEIAES31 views
Machine learning in drug supply chain management during disease outbreaks: a ... by IJECEIAES
Machine learning in drug supply chain management during disease outbreaks: a ...Machine learning in drug supply chain management during disease outbreaks: a ...
Machine learning in drug supply chain management during disease outbreaks: a ...
IJECEIAES10 views
_MAKRIADI-FOTEINI_diploma thesis.pptx by fotinimakriadi
_MAKRIADI-FOTEINI_diploma thesis.pptx_MAKRIADI-FOTEINI_diploma thesis.pptx
_MAKRIADI-FOTEINI_diploma thesis.pptx
fotinimakriadi7 views

Universal apps lightning talk