SlideShare a Scribd company logo
Quasar Framework v1.0
SSR with
Razvan Stoenescu, 7th June 2019
- JSNation -
Short History
Desktop
Apps
Many
programming
languages
Short History
Desktop
Apps
Web server
Websites
HTML CSS
Many
programming
languages
Short History
Desktop
Apps
Web server
Websites
HTML CSS
Many
programming
languages
JS
Short History
Desktop
Apps
Web server
Websites
HTML CSS
Many
programming
languages
JS
CGI Scripts
(C, Perl, ...)
PHP
Short History
Desktop
Apps
Web server
Websites
HTML CSS
Many
programming
languages
JS
CGI Scripts
(C, Perl, ...)
PHP
Short History
Desktop
Apps
Web server
Websites
HTML CSS
Many
programming
languages
Mobile Apps
Many
programming
languages
JS
CGI Scripts
(C, Perl, ...)
PHP
What if...
One codebase
Javascript
What if...
One codebase
Mobile
Apps
Javascript
What if...
One codebase
Desktop
Apps
Mobile
Apps
Javascript
Developing with Quasar
One codebase Websites
Desktop
Apps
Mobile
Apps
SPA
SSR +
PWA
SSR
PWA
Javascript
Developing with Quasar
One codebase
Javascript
Quasar
CLI
What is Quasar?
Quasar
Quasar
UI
Tooling User Interface
Quasar CLI
➔ Project Setup
$ quasar create <folder>
What features do
you want?
Project folder
Quasar CLI
➔ Project Setup
➔ Development
Server
$ quasar dev -m spa
$ quasar dev -m pwa
$ quasar dev -m electron
$ quasar dev -m ssr
$ quasar dev -m
[ios|android]
Project folder
Browser Extensions
Quasar CLI
➔ Project Setup
➔ Development
Server
Hot Module
Reload
Quasar CLI
➔ Project Setup
➔ Development
Server
➔ Build System
All latest and greatest best practices
Quasar CLI
➔ Project Setup
➔ Development
Server
➔ Build System
Minification
(JS & HTML & CSS)
Prefetching
Cache busting
PWA manifest
Lazy loading
Preloading
Tree Shaking
Web Worker
and many more...
Quasar UI
114 Vue components
● Isomorphic
● Material 2.0
Quasar UI
9 Vue directives
Examples:
● v-touch-pan
● v-touch-hold
● v-touch-repeat
● v-scroll
Quasar UI
11 Quasar plugins
Examples:
● Dialog
● Notify
● AppFullscreen
● Loading
● Cookies
● BottomSheet
Quasar UI
6 categories of utils
Examples:
● Date
● Color
● DOM
● Scrolling
Quasar Icon Sets & App space Icons
Fontawesome
Fontawesome Pro
Ionicons
Material
Icons
MDI (Material Design
Icons - extended)
Themify
Icons
Eva Icons
➔ Currently there are 45 Quasar language
packs
➔ RTL mode also transforms user-space
CSS code automatically
➔ Ability to switch from/to RTL mode
dynamically at runtime
Quasar Language Packs & Full RTL Support
How Quasar SSR works
Store
Components
Router
Boot
files
App code
How Quasar SSR works
Store
Components
Router
Boot
files
Quasar CLI
App code /quasar.conf.js
How Quasar SSR works
Store
Components
Router
Boot
files
Quasar CLI
Bundle
renderer
Nodejs
Server
bundle
App code
SSR
Extensions
Server
How Quasar SSR works
Store
Components
Router
Boot
files
Quasar CLI
Bundle
renderer
Nodejs
Server
bundle
App code
SSR
Extensions
Server
Browser
Client
bundle
HTMLHydrates
Renders
Quasar SSR + PWA
SEO for free - Quasar Meta Plugin
SEO for free - Quasar Meta Plugin
Page title
SEO for free - Quasar Meta Plugin
Page title
Meta tags
SEO for free - Quasar Meta Plugin
Page title
Meta tags
<script> or
<link> tags
SEO for free - Quasar Meta Plugin
Page title
Meta tags
<script> or
<link> tags
<body> or
<html> tags
attributes
SEO for free - Quasar Meta Plugin
Page title
Meta tags
<script> or
<link> tags
<body> or
<html> tags
attributes
<noscript>
content
SEO for free - Quasar Meta Plugin
PreFetch feature
PreFetch feature
Router
App
Client
Layouts
Pages
request route
PreFetch feature
Router
App
Client
Layouts
Pages
PreFetch feature
Router
App
Client
Layouts
Pages
Using
preFetch
hooks?
PreFetch feature
Router
App
Client
Layouts
Pages
preFetch
hooks
Store
PreFetch feature
Router
App
Client
Layouts
Pages
preFetch
hooks
Store
render
PreFetch feature
PreFetch feature
PreFetch feature
Boot files
main.js
● Cluttered
● A lot of boilerplate
● Hard to build
SPA/PWA/SSR/Mobile/Desktop
apps without manually adding
complexity
Boot Files
● One file per concern
● No boilerplate
● No additional complexity
● Easy to pick based on build type
through /quasar.conf.js
Boot files
Boot files
Boot files
Handling errors - SERVER
Server-side error
No need to leave the
browser tab!
Handling errors
Client-side error
No need to leave the
browser tab!
Quasar App Extensions
● Configure CLI features
● Add folders/files
● Add CLI commands
● Build, launch and control an API server
● Register UI components
● ....
Input:
image file
@quasar/icon-factory
PWA icons
Cordova
App Icons
Cordova
Splashscreen
PWA
Splashscreen
Electron
App Icons
For all targeted platforms:
● Browsers: Chrome, FF, Safari, IE, ...
● Mobile Apps: iOS, Android
● Desktop Apps: macOS, Windows, Linux
Favicons
SPA Web
Icons
Icon Factory
App Extension
Testing
App Extension
● Unit & e2e testing harnesses
● Product quality auditing tools
● Product security auditing tools
Quasar App Extensions
Community
Community
App Extension
Example
$ quasar ext add remote-dev-tools
Thanks for watching!
https://quasar.dev
forum.quasar.dev
chat.quasar.dev
blog.quasar.dev
@quasarframework

More Related Content

PPTX
Laravel introduction
PDF
Angular 16 – the rise of Signals
PPTX
Laravel development (Laravel History, Environment Setup & Laravel Installatio...
PPTX
Introduction to laravel framework
PDF
Intro to vue.js
PPTX
Laravel Eloquent ORM
PDF
NodeJS for Beginner
PDF
Why Vue.js?
Laravel introduction
Angular 16 – the rise of Signals
Laravel development (Laravel History, Environment Setup & Laravel Installatio...
Introduction to laravel framework
Intro to vue.js
Laravel Eloquent ORM
NodeJS for Beginner
Why Vue.js?

What's hot (20)

PPTX
Intro to Node.js (v1)
PDF
Why and How to Use Virtual DOM
PPTX
.Net Core
PDF
MySQL InnoDB Cluster HA Overview & Demo
PPTX
Angular 14.pptx
PDF
An introduction to Vue.js
PPTX
Introduction Node.js
PPTX
Intro to React
PPTX
Laravel
PDF
Laravel 101
PPTX
REST-API introduction for developers
PDF
Why Laravel?
PPTX
Reactjs workshop
PPT
Vue.js Getting Started
PDF
[오픈소스컨설팅]RHEL7/CentOS7 Pacemaker기반-HA시스템구성-v1.0
PPTX
Selenium WebDriver
PDF
FRONT-END WEB DEVELOPMENT WITH REACTJS
PPTX
Node js introduction
PPTX
Ef code first
PPTX
Introduction to Laravel Framework (5.2)
Intro to Node.js (v1)
Why and How to Use Virtual DOM
.Net Core
MySQL InnoDB Cluster HA Overview & Demo
Angular 14.pptx
An introduction to Vue.js
Introduction Node.js
Intro to React
Laravel
Laravel 101
REST-API introduction for developers
Why Laravel?
Reactjs workshop
Vue.js Getting Started
[오픈소스컨설팅]RHEL7/CentOS7 Pacemaker기반-HA시스템구성-v1.0
Selenium WebDriver
FRONT-END WEB DEVELOPMENT WITH REACTJS
Node js introduction
Ef code first
Introduction to Laravel Framework (5.2)
Ad

Similar to SSR with Quasar Framework - JSNation 2019 (20)

PPTX
Intro to Azure Static Web Apps
PDF
NextJS, A JavaScript Framework for building next generation SPA
PPT
내꺼내꺼
PPTX
Software components design for poc and mvp, keep it simple but be ready to sc...
PDF
Alexander Mostovenko "'Devide at impera' with GraphQL and SSR"
PDF
Summit Australia 2019 - PowerApp Portals - Andrew Ly & Lachlan Wright
PPTX
Microsoft WebMatrix Platform Overview
PPTX
StrongLoop Overview
PDF
SUG Meetup Budapest April 2025 Peter Prochazka Better XM/XP Deployments With ...
PDF
CTU June 2011 - Things that Every ASP.NET Developer Should Know
PDF
Next.js Introduction
PDF
Seattle StrongLoop Node.js Workshop
PDF
SUGCON Europe 2025 Peter Prochazka - Better XM/XP Deployments With Kubernetes
PPTX
PHP on Windows
PPTX
PHP on Windows
PPT
Mashups
KEY
NDC 2011 - Let me introduce my Moncai
PDF
Jax WS JAX RS and Java Web Apps with WSO2 Platform
PDF
Netapp Michael Galpin
KEY
Modular Web Applications With Netzke
Intro to Azure Static Web Apps
NextJS, A JavaScript Framework for building next generation SPA
내꺼내꺼
Software components design for poc and mvp, keep it simple but be ready to sc...
Alexander Mostovenko "'Devide at impera' with GraphQL and SSR"
Summit Australia 2019 - PowerApp Portals - Andrew Ly & Lachlan Wright
Microsoft WebMatrix Platform Overview
StrongLoop Overview
SUG Meetup Budapest April 2025 Peter Prochazka Better XM/XP Deployments With ...
CTU June 2011 - Things that Every ASP.NET Developer Should Know
Next.js Introduction
Seattle StrongLoop Node.js Workshop
SUGCON Europe 2025 Peter Prochazka - Better XM/XP Deployments With Kubernetes
PHP on Windows
PHP on Windows
Mashups
NDC 2011 - Let me introduce my Moncai
Jax WS JAX RS and Java Web Apps with WSO2 Platform
Netapp Michael Galpin
Modular Web Applications With Netzke
Ad

Recently uploaded (20)

PDF
Getting Started with Data Integration: FME Form 101
PDF
Network Security Unit 5.pdf for BCA BBA.
PDF
A comparative analysis of optical character recognition models for extracting...
PPTX
1. Introduction to Computer Programming.pptx
PPTX
A Presentation on Artificial Intelligence
PPTX
20250228 LYD VKU AI Blended-Learning.pptx
PDF
Agricultural_Statistics_at_a_Glance_2022_0.pdf
PDF
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
PDF
MIND Revenue Release Quarter 2 2025 Press Release
PDF
Optimiser vos workloads AI/ML sur Amazon EC2 et AWS Graviton
PDF
Reach Out and Touch Someone: Haptics and Empathic Computing
PDF
Advanced methodologies resolving dimensionality complications for autism neur...
PDF
Video forgery: An extensive analysis of inter-and intra-frame manipulation al...
PPTX
Group 1 Presentation -Planning and Decision Making .pptx
PDF
Machine learning based COVID-19 study performance prediction
PDF
Empathic Computing: Creating Shared Understanding
PDF
cuic standard and advanced reporting.pdf
PPTX
Programs and apps: productivity, graphics, security and other tools
PDF
Accuracy of neural networks in brain wave diagnosis of schizophrenia
PDF
NewMind AI Weekly Chronicles - August'25-Week II
Getting Started with Data Integration: FME Form 101
Network Security Unit 5.pdf for BCA BBA.
A comparative analysis of optical character recognition models for extracting...
1. Introduction to Computer Programming.pptx
A Presentation on Artificial Intelligence
20250228 LYD VKU AI Blended-Learning.pptx
Agricultural_Statistics_at_a_Glance_2022_0.pdf
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
MIND Revenue Release Quarter 2 2025 Press Release
Optimiser vos workloads AI/ML sur Amazon EC2 et AWS Graviton
Reach Out and Touch Someone: Haptics and Empathic Computing
Advanced methodologies resolving dimensionality complications for autism neur...
Video forgery: An extensive analysis of inter-and intra-frame manipulation al...
Group 1 Presentation -Planning and Decision Making .pptx
Machine learning based COVID-19 study performance prediction
Empathic Computing: Creating Shared Understanding
cuic standard and advanced reporting.pdf
Programs and apps: productivity, graphics, security and other tools
Accuracy of neural networks in brain wave diagnosis of schizophrenia
NewMind AI Weekly Chronicles - August'25-Week II

SSR with Quasar Framework - JSNation 2019