SlideShare a Scribd company logo
SINGLE PAGE
APPLICATIONS
Andriy Deren’, Dreams IT, CEO
Ternopil JS #2
AGENDA
▪ What is SPA?
▪ SPA architecture design
▪ SPA Back-end
▪ SPA Client-side
▪ MVVM & SPA implementation
▪ SPA Advanced techniques
MODERN WEB CHALLENGES
▪ More in-page interactivity
▪ Rich client graphics
▪ Data growth
▪ Page size growth
▪ New client devices
▪ Reloads vs Native feeling
CLASSIC WEB PAGES
/GET /home/index
Browser Web-server Server-side
magic
A lot of HTML, CSS, JS on each click
Main.css
super_script.js
CLASSIC WEB PAGES
/GET /home/index
Browser Web-server Server-side
magic
A lot of HTML, CSS, JS on each click
Main.css
super_script.js
Reloads & redirects
SINGLE PAGE APPLICATION
/GET /home/indexBrowser
Web-server Server-side
magic
Load tiny html template
Main.css
super_script.js
Load required data
SINGLE PAGE APPLICATION
Browser
Client-side
magic
Fill template with data
Bind actions behavior
Client-side routing
All actions and redirects
are handled on client-side
With no page reload
and huge HTML packages
SPA ARCHITECTURE DESIGN
Routing Action Behaviors
Data Provider &
Data context
State (Storage)
Security
(authorization &
authentication)
Data AccessBack-end
Middle-ware
Views &
Templates
Bindings Custom scriptsFront-end
CLIENTSIDE
SPA BACK-END
State (Storage)
Security
(authorization &
authentication)
Data Access
▪ Data storage
▪ User-specific data
▪ Security actions
▪ Provide access to resources (via HTTP REST API)
SPA BACK-END
State (Storage)
Security
(authorization &
authentication)
Data Access
▪ Minimal delay
▪ Maximal efficiency
▪ High scale
▪ Versioning
▪ Conventions
GET /api/v1/product/32
Good resource route
GET /product.php?v=1&id=32&action=getProduct
Bad resource route
SPA BACK-END
State (Storage)
Security
(authorization &
authentication)
Data Access
SPA MIDDLE WARE
▪ Data context: Models, Data Provider & App State
▪ Routing: client-side navigation
▪ User actions reaction
Routing Action Behaviors
Data Provider &
Data context
SPA FRONT-END
▪ State bindings: connect app state and UI elements
▪ Load & select right views
▪ Run custom scripts (jQuery, animation, transitions, etc.)
Views &
Templates
Bindings Custom scripts
View
MVVM PATTERN
View View Model Model
View Behavior (UI Logic)
Notifications
Bindings
Commands
Data transfer
UI Presentation Layer Data Layer and BL
View
SPA COMPONENTS
View
Views and
templates
(HTML fragments)
View models
Router + routing
configuration
(navigation)
Custom scripts
Data providers &
data transfer
SPA Shell
SPA
UNDER THE HOOD
example.com/#products
example.com/#products/details/12
Routing
Uses History API
(back button works!)
<h3 class="app-title" data-bind="text:$data.title">
…
Bindings
Data bindings
(by code, markup, etc.)
<a data-bind="click:$root.showDetails">…
Behavior bindings
(by code, markup, etc.)
IMPLEMENTATION TECHNOLOGIES
SPA ADVANCED TECHNIQUES
▪ Architecture design with implementation in mind
▪ Simplify client-side code (TypeScript, Coffee)
▪ Dependencies injection & modules (RequireJS)
▪ Testing
▪ Attention to efficiency and performance
▪ Search engines optimization
THANK YOU!
Any questions?

More Related Content

PPTX
Single Page Applications on JavaScript and ASP.NET MVC4
PDF
Progressive Web Apps - Covering the best of both worlds
PPTX
Pros and Cons of developing a Thick Clientside App
PPTX
Spicing up SharePoint web parts
PPTX
Web-centric application architectures
PPTX
Building rich Single Page Applications (SPAs) for desktop, mobile, and tablet...
DOC
Single Page Applications on JavaScript and ASP.NET MVC4
Progressive Web Apps - Covering the best of both worlds
Pros and Cons of developing a Thick Clientside App
Spicing up SharePoint web parts
Web-centric application architectures
Building rich Single Page Applications (SPAs) for desktop, mobile, and tablet...

What's hot (20)

PPTX
Ajax technology
PDF
Ajax basics
PDF
Single Page Apps
PPTX
Introduction to web application development
PDF
Progressive Web Apps - Covering the best of both worlds - DevReach
PDF
Client Side MVC with Backbone and Rails
PPTX
Single Page Apps
PPTX
Responsive Web Development
PPT
PPTX
Basics of Silverlight 1
PPT
Performance anti patterns in ajax applications
PPT
TSSJS2010 Presenatation on: Performance Anti Patterns In Ajax Applications
PPTX
Overview of AJAX
ODP
Ajax
PPT
From Mess To CMS: the transformation of a library website
PDF
Ajax World West
PPTX
Web Developer Roadmap 2014 by Brennan Heyde
PPTX
Back to the Basics - 1 - Introduction to Web Development
PPTX
CakePHP, cakePHP development Company
Ajax technology
Ajax basics
Single Page Apps
Introduction to web application development
Progressive Web Apps - Covering the best of both worlds - DevReach
Client Side MVC with Backbone and Rails
Single Page Apps
Responsive Web Development
Basics of Silverlight 1
Performance anti patterns in ajax applications
TSSJS2010 Presenatation on: Performance Anti Patterns In Ajax Applications
Overview of AJAX
Ajax
From Mess To CMS: the transformation of a library website
Ajax World West
Web Developer Roadmap 2014 by Brennan Heyde
Back to the Basics - 1 - Introduction to Web Development
CakePHP, cakePHP development Company
Ad

Viewers also liked (20)

PPTX
DV 2016: The Death of 'Anonymous'
PDF
NCI HDip Data Analysis students, Class of 2015
PPTX
Why apps
PDF
Setting Yourself up for Success: Building an Analytics Schema and Data Dictio...
PDF
مرزا غالب ۔ دیوان نعت و منقبت
PDF
Single_Customer_View_eBook
PPTX
Master Cross-Channel Customer Recognition
PPTX
Powering Omnichannel Experiences with Real-Time Data
DOCX
Aruna (Resume)
PPTX
The role of assessment center in managing employees' placement
PDF
One-Man Ops
PDF
People-Based Marketing: The Next Frontier for Harnessing the Power of First-P...
PDF
チャットツールをSlackだけにしたい話ver1 00
PDF
Presentation asonika ru_en
PDF
Stylefruits - NOAH14 London
PPTX
Marketing Automation part 3 of 4
PDF
2015.4.23 Segment Autopilot Webinar Deck_final 2
PPTX
MAU Vegas 2016 — Tackling Retention During Activation
PDF
DJC16 seminar - Presentatie Joost Kaart NS
DV 2016: The Death of 'Anonymous'
NCI HDip Data Analysis students, Class of 2015
Why apps
Setting Yourself up for Success: Building an Analytics Schema and Data Dictio...
مرزا غالب ۔ دیوان نعت و منقبت
Single_Customer_View_eBook
Master Cross-Channel Customer Recognition
Powering Omnichannel Experiences with Real-Time Data
Aruna (Resume)
The role of assessment center in managing employees' placement
One-Man Ops
People-Based Marketing: The Next Frontier for Harnessing the Power of First-P...
チャットツールをSlackだけにしたい話ver1 00
Presentation asonika ru_en
Stylefruits - NOAH14 London
Marketing Automation part 3 of 4
2015.4.23 Segment Autopilot Webinar Deck_final 2
MAU Vegas 2016 — Tackling Retention During Activation
DJC16 seminar - Presentatie Joost Kaart NS
Ad

Similar to Single page applications - TernopilJS #2 (20)

PDF
Server rendering-talk
PDF
Metrics that Matter-Approaches To Managing High Performing Websites
PDF
L13 Presentation Layer Design
PPT
Application Performance Lecture
PDF
REST - What's It All About? (SAP TechEd 2012, CD110)
PPTX
Benefits of developing single page web applications using angular js
PDF
Adding Data into your SOA with WSO2 WSAS
PPTX
Extreme Ria Using Dnn
PDF
The future of web development write once, run everywhere with angular js an...
PPTX
The future of web development write once, run everywhere with angular.js and ...
PPTX
REST: So What's It All About? (SAP TechEd 2011, MOB107)
PDF
Mstr meetup
PDF
Magnolia & Angular JS - an Approach for Javascript RIAs Delivered by a CMS
PDF
Applications of the REST Principle
PPTX
ASP.net MVC Introduction Wikilogia (nov 2014)
PPT
Rich internet application (ria)
PPTX
Uniface Lectures Webinar - Building Responsive Applications with Uniface: Get...
PPTX
Single page applications
PPTX
AngularJS training - Day 1 - Basics: Why, What and basic features of AngularJS
PPTX
L19 Application Architecture
Server rendering-talk
Metrics that Matter-Approaches To Managing High Performing Websites
L13 Presentation Layer Design
Application Performance Lecture
REST - What's It All About? (SAP TechEd 2012, CD110)
Benefits of developing single page web applications using angular js
Adding Data into your SOA with WSO2 WSAS
Extreme Ria Using Dnn
The future of web development write once, run everywhere with angular js an...
The future of web development write once, run everywhere with angular.js and ...
REST: So What's It All About? (SAP TechEd 2011, MOB107)
Mstr meetup
Magnolia & Angular JS - an Approach for Javascript RIAs Delivered by a CMS
Applications of the REST Principle
ASP.net MVC Introduction Wikilogia (nov 2014)
Rich internet application (ria)
Uniface Lectures Webinar - Building Responsive Applications with Uniface: Get...
Single page applications
AngularJS training - Day 1 - Basics: Why, What and basic features of AngularJS
L19 Application Architecture

More from Andriy Deren' (6)

PPTX
Onlizer product overview
PPTX
Microsoft Build 2018 news for .NET developers
PPTX
Onlizer - November 2016 Review
PPTX
Onlizer IoT Foundation
PPTX
GDG Ternopil TechTalks Web #1 2015 - Data storages in Microsoft Azure
PPTX
Onlizer - Project review for SE2015
Onlizer product overview
Microsoft Build 2018 news for .NET developers
Onlizer - November 2016 Review
Onlizer IoT Foundation
GDG Ternopil TechTalks Web #1 2015 - Data storages in Microsoft Azure
Onlizer - Project review for SE2015

Recently uploaded (20)

PDF
AI in Product Development-omnex systems
PDF
medical staffing services at VALiNTRY
PDF
Upgrade and Innovation Strategies for SAP ERP Customers
PPT
JAVA ppt tutorial basics to learn java programming
PDF
System and Network Administraation Chapter 3
PPTX
Online Work Permit System for Fast Permit Processing
PDF
How to Choose the Right IT Partner for Your Business in Malaysia
PDF
PTS Company Brochure 2025 (1).pdf.......
PPTX
Transform Your Business with a Software ERP System
PDF
Design an Analysis of Algorithms II-SECS-1021-03
PPTX
Essential Infomation Tech presentation.pptx
PPTX
L1 - Introduction to python Backend.pptx
PDF
2025 Textile ERP Trends: SAP, Odoo & Oracle
PPTX
history of c programming in notes for students .pptx
PDF
Wondershare Filmora 15 Crack With Activation Key [2025
PPTX
ManageIQ - Sprint 268 Review - Slide Deck
PDF
Audit Checklist Design Aligning with ISO, IATF, and Industry Standards — Omne...
PDF
Which alternative to Crystal Reports is best for small or large businesses.pdf
PDF
Complete React Javascript Course Syllabus.pdf
PPTX
Lecture 3: Operating Systems Introduction to Computer Hardware Systems
AI in Product Development-omnex systems
medical staffing services at VALiNTRY
Upgrade and Innovation Strategies for SAP ERP Customers
JAVA ppt tutorial basics to learn java programming
System and Network Administraation Chapter 3
Online Work Permit System for Fast Permit Processing
How to Choose the Right IT Partner for Your Business in Malaysia
PTS Company Brochure 2025 (1).pdf.......
Transform Your Business with a Software ERP System
Design an Analysis of Algorithms II-SECS-1021-03
Essential Infomation Tech presentation.pptx
L1 - Introduction to python Backend.pptx
2025 Textile ERP Trends: SAP, Odoo & Oracle
history of c programming in notes for students .pptx
Wondershare Filmora 15 Crack With Activation Key [2025
ManageIQ - Sprint 268 Review - Slide Deck
Audit Checklist Design Aligning with ISO, IATF, and Industry Standards — Omne...
Which alternative to Crystal Reports is best for small or large businesses.pdf
Complete React Javascript Course Syllabus.pdf
Lecture 3: Operating Systems Introduction to Computer Hardware Systems

Single page applications - TernopilJS #2