SlideShare a Scribd company logo
INTRODUCTION TO
SINGLE PAGE APPLICATION
WEBINAR
KMS TECHNOLOGY INC.
29 | 01 | 2015
$ WHOAMI
Nguyễn Lê Phú An
Senior Software Engineer
R&D, KMS Technology Inc.
anlpnguyen@kms-technology.com
INTRODUCTION TO SINGLE PAGE APPLICATION
An Nguyen
LET’S DESCRIBE YOURSELF
What is SPA?
I heard that before
I’m working on that
I’m a guru!
INTRODUCTION TO SINGLE PAGE APPLICATION
AGENDA
Traditional website
Evolution
Single Page Application
Challenges
Takeaways
INTRODUCTION TO SINGLE PAGE APPLICATION
Traditional Website
INTRODUCTION TO SINGLE PAGE APPLICATION
COMPONENTS
TRADITIONAL WEBSITE
SERVER-BASED APPLICATION
TRADITIONAL WEBSITE
MULTIPLE PAGES
TRADITIONAL WEBSITE
Evolution
INTRODUCTION TO SINGLE PAGE APPLICATION
NOWADAYS
• Modern browsers
• JavaScript becomes more powerful
• HTML5 - Thank God! You’re here
• More focus on UX (User Experience)
EVOLUTION
CHANGES
EVOLUTION
• App-like user experience
• Faster UI, more interactive
• Be able to work Offline
• Support multiple platforms (responsive design)
Single Page Application
Single Page Application
INTRODUCTION TO SINGLE PAGE APPLICATION
SPA – SINGLE PAGE APPLICATION
SINGLE PAGE APPLICATION
• A next evolution from traditional website
• Web apps that load a single HTML page
• SPAs use AJAX and HTML5 to create fluid and responsive
Web apps, without constant page reloads
SPA – SINGLE PAGE APPLICATION
SINGLE PAGE APPLICATION
BENEFITS
SINGLE PAGE APPLICATION
• No page flicker
• Javascript-based rendering
• Better UX
• Faster interaction
PRINCIPLES
SINGLE PAGE APPLICATION
• Performance matters
• Things you did on the server now live in the
browser
• Render with JavaScript (library)
• Use CSS3
• Design with Offline in mind
Examples
INTRODUCTION TO SINGLE PAGE APPLICATION
HOW CAN I BUILD A SPA?
SINGLE PAGE APPLICATION
• Keep the principles in your mind
• Use a JavaScript framework adopted the
principles
THAT’S IT???
SINGLE PAGE APPLICATION
Challenges
INTRODUCTION TO SINGLE PAGE APPLICATION
SEARCH ENGINE OPTIMIZATION
CHALLENGES
SEARCH ENGINE OPTIMIZATION
SOLUTION
– Client side has to optimize the keywords, tags…
– Server side has to do 2 jobs:
• Transfer data to client for SPA
• Render whole website for Search Engine bot
CHALLENGES
SPEED OF INITIAL LOAD
CHALLENGES
SPEED OF INITIAL LOAD
SOLUTION
CHALLENGES
Caching & Lazy-loading
But… we can’t avoid that
BROWSER HISTORY
CHALLENGES
BROWSER HISTORY
SOLUTION
CHALLENGES
• Write JS code to handle the histories
• Use HTML5 pushState
GOOGLE ANALYTICS
CHALLENGES
GOOGLE ANALYTICS
SOLUTION
CHALLENGES
Manually
CLIENT/SERVER CODE
PARTITIONING
CHALLENGES
CLIENT/SERVER CODE
PARTITIONING - SOLUTION
CHALLENGES
• Use a logic-less template language
• UI data binding
Takeaways
INTRODUCTION TO SINGLE PAGE APPLICATION
TAKEAWAYS
• Remind the traditional website
– HTML, JS & CSS
– Server-based application
• Introduction to SPA
• SPA principles
• Challenges
– SEO, Slow Initial Page, Browser History
– …
CHALLENGES
Q&A
Is my website suitable to apply SPA?
INTRODUCTION TO SINGLE PAGE APPLICATION
THANK YOU
© 2013 KMS Technology

More Related Content

PPTX
Web Development
PDF
Conception et réalisation d’un Système d’information des étudiants du départe...
PPTX
An Introduction to Content Marketing
PPTX
Website traffic
PPTX
Data Quality for Machine Learning Tasks
PPT
Bootstrap Part - 1
PDF
How to train your robot (with Deep Reinforcement Learning)
ODP
The Full Stack Web Development
Web Development
Conception et réalisation d’un Système d’information des étudiants du départe...
An Introduction to Content Marketing
Website traffic
Data Quality for Machine Learning Tasks
Bootstrap Part - 1
How to train your robot (with Deep Reinforcement Learning)
The Full Stack Web Development

What's hot (20)

PPTX
Node.js Express
PPTX
Introduction to Node.js
PDF
Getting started with Next.js
PDF
Api presentation
PPTX
React-JS.pptx
PDF
ReactJS presentation
PPTX
What Is Express JS?
PPTX
Introduction to MERN
PDF
Angular Directives
PPTX
Angular Data Binding
PPTX
Introduction to React JS for beginners
PDF
PPTX
[Final] ReactJS presentation
PPTX
React workshop
PPTX
Introduction to Web Development
PPTX
Unit 1 - TypeScript & Introduction to Angular CLI.pptx
PDF
Node.js Tutorial for Beginners | Node.js Web Application Tutorial | Node.js T...
PPT
PPTX
Python/Flask Presentation
PDF
NextJS, A JavaScript Framework for building next generation SPA
Node.js Express
Introduction to Node.js
Getting started with Next.js
Api presentation
React-JS.pptx
ReactJS presentation
What Is Express JS?
Introduction to MERN
Angular Directives
Angular Data Binding
Introduction to React JS for beginners
[Final] ReactJS presentation
React workshop
Introduction to Web Development
Unit 1 - TypeScript & Introduction to Angular CLI.pptx
Node.js Tutorial for Beginners | Node.js Web Application Tutorial | Node.js T...
Python/Flask Presentation
NextJS, A JavaScript Framework for building next generation SPA
Ad

Viewers also liked (15)

PDF
Introduction to the MEAN stack
PPT
Get MEAN! Node.js and the MEAN stack
PDF
Single Page Applications
PPTX
Building single page applications
PPTX
Single Page Application (SPA) using AngularJS
PDF
MEAN Stack
PPT
The MEAN Stack: MongoDB, ExpressJS, AngularJS and Node.js
PDF
Does my DIV look big in this?
PPT
Single Page Application presentation
PDF
AngularJS 101 - Everything you need to know to get started
PPTX
AngularJS Architecture
PDF
AngularJS application architecture
PPTX
Introduction to Angularjs
PDF
AngularJS Basics with Example
ODP
Introduction to Angular 2
Introduction to the MEAN stack
Get MEAN! Node.js and the MEAN stack
Single Page Applications
Building single page applications
Single Page Application (SPA) using AngularJS
MEAN Stack
The MEAN Stack: MongoDB, ExpressJS, AngularJS and Node.js
Does my DIV look big in this?
Single Page Application presentation
AngularJS 101 - Everything you need to know to get started
AngularJS Architecture
AngularJS application architecture
Introduction to Angularjs
AngularJS Basics with Example
Introduction to Angular 2
Ad

Similar to Introduction To Single Page Application (20)

PPTX
Relax, it's spa time
PPTX
Single page App
PPTX
Single Page Apps
PPTX
Building WordPress sites with AngularJS and the RESTful plugin JSON API @ Dev...
PPTX
SPA Philly Code Camp
PPTX
Introduction to AngularJS
PPTX
Java vs javascript (XPages)
PPTX
Next-Gen CMS Emerging Trends Shaping the Future of WordPress Development
PDF
Introducing Support for Dynamic Websites
PPTX
Develop a vanilla.js spa you and your customers will love
PDF
Introduction tosinglepageapplications
PPTX
Pearls and Must-Have Tools for the Modern Web / .NET Developer
PDF
BD Conf: Visit speed - Page speed is only the beginning
PPTX
Front End page speed performance improvements for Drupal
PPTX
Front End page speed performance improvements for Drupal
PDF
How to be Successful with Responsive Sites (Koombea & NGINX) - English
PDF
How to deal with mobile traffic expansion
PPTX
Web Developer Jobs in Jaipur for Freshers Your Gateway to a Bright Tech Caree...
PPTX
Responsive Design and Information Architecture with Oracle Web Center Content...
PDF
Isomorphic Aplication with Javascript
Relax, it's spa time
Single page App
Single Page Apps
Building WordPress sites with AngularJS and the RESTful plugin JSON API @ Dev...
SPA Philly Code Camp
Introduction to AngularJS
Java vs javascript (XPages)
Next-Gen CMS Emerging Trends Shaping the Future of WordPress Development
Introducing Support for Dynamic Websites
Develop a vanilla.js spa you and your customers will love
Introduction tosinglepageapplications
Pearls and Must-Have Tools for the Modern Web / .NET Developer
BD Conf: Visit speed - Page speed is only the beginning
Front End page speed performance improvements for Drupal
Front End page speed performance improvements for Drupal
How to be Successful with Responsive Sites (Koombea & NGINX) - English
How to deal with mobile traffic expansion
Web Developer Jobs in Jaipur for Freshers Your Gateway to a Bright Tech Caree...
Responsive Design and Information Architecture with Oracle Web Center Content...
Isomorphic Aplication with Javascript

More from KMS Technology (20)

PDF
A journey to a Full Stack Tester
PDF
React & Redux, how to scale?
PDF
Sexy React Stack
PDF
Common design principles and design patterns in automation testing
PDF
[Webinar] Test First, Fail Fast - Simplifying the Tester's Transition to DevOps
PDF
KMSNext Roadmap
PDF
KMS Introduction
PDF
What's new in the Front-end development nowadays?
PDF
JavaScript - No Longer A Toy Language
PDF
JavaScript No longer A “toy” Language
PDF
Preparations For A Successful Interview
PDF
AWS: Scaling With Elastic Beanstalk
PDF
Behavior-Driven Development and Automation Testing Using Cucumber Framework W...
PDF
KMS Introduction
PDF
Technology Application Development Trends For IT Students
PDF
Contributors for Delivering a Successful Testing Project Seminar
PDF
Increase Chances to Be Hired as Software Developers - 2014
PDF
Behavior Driven Development and Automation Testing Using Cucumber
PDF
Software Technology Trends in 2013-2014
PDF
Cross-platform Mobile Development with C# and Xamarin Webinar
A journey to a Full Stack Tester
React & Redux, how to scale?
Sexy React Stack
Common design principles and design patterns in automation testing
[Webinar] Test First, Fail Fast - Simplifying the Tester's Transition to DevOps
KMSNext Roadmap
KMS Introduction
What's new in the Front-end development nowadays?
JavaScript - No Longer A Toy Language
JavaScript No longer A “toy” Language
Preparations For A Successful Interview
AWS: Scaling With Elastic Beanstalk
Behavior-Driven Development and Automation Testing Using Cucumber Framework W...
KMS Introduction
Technology Application Development Trends For IT Students
Contributors for Delivering a Successful Testing Project Seminar
Increase Chances to Be Hired as Software Developers - 2014
Behavior Driven Development and Automation Testing Using Cucumber
Software Technology Trends in 2013-2014
Cross-platform Mobile Development with C# and Xamarin Webinar

Recently uploaded (20)

PDF
CIFDAQ's Token Spotlight: SKY - A Forgotten Giant's Comeback?
PDF
KodekX | Application Modernization Development
PDF
DevOps & Developer Experience Summer BBQ
PPTX
breach-and-attack-simulation-cybersecurity-india-chennai-defenderrabbit-2025....
PDF
Top Generative AI Tools for Patent Drafting in 2025.pdf
PDF
Building High-Performance Oracle Teams: Strategic Staffing for Database Manag...
PDF
HCSP-Presales-Campus Network Planning and Design V1.0 Training Material-Witho...
PPTX
Web Security: Login Bypass, SQLi, CSRF & XSS.pptx
PPTX
ABU RAUP TUGAS TIK kelas 8 hjhgjhgg.pptx
PDF
CIFDAQ's Market Wrap: Ethereum Leads, Bitcoin Lags, Institutions Shift
PPTX
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy
PDF
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
PPTX
Understanding_Digital_Forensics_Presentation.pptx
PPTX
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
PDF
Reimagining Insurance: Connected Data for Confident Decisions.pdf
PDF
How AI Agents Improve Data Accuracy and Consistency in Due Diligence.pdf
PDF
A Day in the Life of Location Data - Turning Where into How.pdf
PDF
Automating ArcGIS Content Discovery with FME: A Real World Use Case
PDF
Shreyas Phanse Resume: Experienced Backend Engineer | Java • Spring Boot • Ka...
PDF
ai-archetype-understanding-the-personality-of-agentic-ai.pdf
CIFDAQ's Token Spotlight: SKY - A Forgotten Giant's Comeback?
KodekX | Application Modernization Development
DevOps & Developer Experience Summer BBQ
breach-and-attack-simulation-cybersecurity-india-chennai-defenderrabbit-2025....
Top Generative AI Tools for Patent Drafting in 2025.pdf
Building High-Performance Oracle Teams: Strategic Staffing for Database Manag...
HCSP-Presales-Campus Network Planning and Design V1.0 Training Material-Witho...
Web Security: Login Bypass, SQLi, CSRF & XSS.pptx
ABU RAUP TUGAS TIK kelas 8 hjhgjhgg.pptx
CIFDAQ's Market Wrap: Ethereum Leads, Bitcoin Lags, Institutions Shift
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
Understanding_Digital_Forensics_Presentation.pptx
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
Reimagining Insurance: Connected Data for Confident Decisions.pdf
How AI Agents Improve Data Accuracy and Consistency in Due Diligence.pdf
A Day in the Life of Location Data - Turning Where into How.pdf
Automating ArcGIS Content Discovery with FME: A Real World Use Case
Shreyas Phanse Resume: Experienced Backend Engineer | Java • Spring Boot • Ka...
ai-archetype-understanding-the-personality-of-agentic-ai.pdf

Introduction To Single Page Application