SlideShare a Scribd company logo
Scalable Front-end
Development with Vue.JS
Galih Pratama
Head Front-end Developer at
Who are you?
Galih Pratama
Front-end Developer with 30+ web/apps developed.
Tech-based Edu Content Creator with 100+ videos
created, since 2011.
Current Work / Projects
Me in a nutshell
Current State of Javascript
stateofjs.com/2017/front-end/results
stateofjs.com/2017/opinions
stateofdev.com/c/frontend
What is “Scalable
Development” means?
Improve development speed
Decrease future technical debt
Modular
Good programming pattern
Not over-engineering things
Scalable Front-end Development with Vue.JS
Why Vue.JS?
You can use it simply like this...
Scalable Front-end Development with Vue.JS
...or like this...
Scalable Front-end Development with Vue.JS
Learning curve is easy Hot reload
Two-way data binding
Less boilerplate code
Vuex
Vue Devtools
vue-cli
Small file size
Can used on existing app
Detailed documentation
Write HTML like an usual
Reactive
Fun
Flexible
Simplicity
Single page apps
Single Page Apps (SPA)
Why SPA?
App rendered in browser
Less server overhead
(no need to render anything in server, only serve html/css/js)
Separation of Concerns
(frontend do frontend, backend do backend)
Routing? Included.
vue-router
Wuzz wuzz
Scalable Front-end Development with Vue.JS
Vue Devtools
Makes developing on Vue.js even easier than it already is.
Scalable Front-end Development with Vue.JS
Scalable Front-end Development with Vue.JS
Scalable Front-end Development with Vue.JS
vue-cli
A simple CLI for scaffolding Vue.js projects.
vue init <templatename> <projectname>
Scalable Front-end Development with Vue.JS
You can use it in any way!
● webpack
A full-featured Webpack + vue-loader setup with hot reload, linting, testing & css extraction.
● webpack-simple
A simple Webpack + vue-loader setup for quick prototyping.
● browserify
A full-featured Browserify + vueify setup with hot-reload, linting & unit testing.
● browserify-simple
A simple Browserify + vueify setup for quick prototyping.
● pwa
PWA template for vue-cli based on the webpack template
● simple
The simplest possible Vue setup in a single HTML file
Vuex
Vue.js on Steroids
How Vue.js “one-way data flow” lifecycle works
The problem?
> One state for multiple component
> Reusable action from different component
How to handle this?
Solution?
Scalable Front-end Development with Vue.JS
Scalable Front-end Development with Vue.JS
Scalable Front-end Development with Vue.JS
Vuex Store
A place to “store” globally in your app
Scalable Front-end Development with Vue.JS
Vuex State Vue Data
Vuex Action Vue Methods
How About SEO?
Google(bot) can index Single Page Apps
Scalable Front-end Development with Vue.JS
Scalable Front-end Development with Vue.JS
SPA & Googlebot
● Googlebot run the Javascript on the page and the Ajax calls are properly executed
● Googlebot waits between 5 to 20 seconds before taking a snapshot of each page
More :
https://medium.com/@l.mugnaini/spa-and-seo-is-googlebot-able-to-render-a-single-page-application-1f74e706ab11
Scalable Front-end Development with Vue.JS
Prerender?
Use prerender-spa-plugin
Server-side rendering?
Use Nuxt.js instead
Conclusion
1. Building javascript apps is somewhat confusing
2. Need to scale up without make it more complicated.
3. Vue.JS make it easier without sacrificing scalability.
4. Official project generator using vue-cli
5. Ready to use devtools with zero configuration
6. Use Vuex in large-scale apps
7. SEO is safe (like Google said)
Conclusion
Thank….
… one more thing
Want to know how
to build it ?
Thank you!
Questions?
galpratama pratama.galih hi@galihpratama.net

More Related Content

What's hot (20)

VueJS Introduction
VueJS Introduction
David Ličen
 
Vue 2.0 + Vuex Router & Vuex at Vue.js
Vue 2.0 + Vuex Router & Vuex at Vue.js
Takuya Tejima
 
Why Vue.js?
Why Vue.js?
Jonathan Goode
 
How to Build SPA with Vue Router 2.0
How to Build SPA with Vue Router 2.0
Takuya Tejima
 
Vue JS Intro
Vue JS Intro
Muhammad Rizki Rijal
 
Vue js 大型專案架構
Vue js 大型專案架構
Hina Chen
 
Vue.js
Vue.js
Jadson Santos
 
Javascript MVVM with Vue.JS
Javascript MVVM with Vue.JS
Eueung Mulyana
 
VueJS: The Simple Revolution
VueJS: The Simple Revolution
Rafael Casuso Romate
 
Vuex
Vuex
Asaquzzaman Mishu
 
Vue js and Vue Material
Vue js and Vue Material
Eueung Mulyana
 
Vuejs for Angular developers
Vuejs for Angular developers
Mikhail Kuznetcov
 
Vue.js
Vue.js
BADR
 
Introduction to VueJS & Vuex
Introduction to VueJS & Vuex
Bernd Alter
 
Vue, vue router, vuex
Vue, vue router, vuex
Samundra khatri
 
Modern frontend development with VueJs
Modern frontend development with VueJs
Tudor Barbu
 
Vue.js for beginners
Vue.js for beginners
Julio Bitencourt
 
An introduction to Vue.js
An introduction to Vue.js
Pagepro
 
第一次用 Vue.js 就愛上 [改]
第一次用 Vue.js 就愛上 [改]
Kuro Hsu
 
Vue Introduction
Vue Introduction
Elad Gasner
 
VueJS Introduction
VueJS Introduction
David Ličen
 
Vue 2.0 + Vuex Router & Vuex at Vue.js
Vue 2.0 + Vuex Router & Vuex at Vue.js
Takuya Tejima
 
How to Build SPA with Vue Router 2.0
How to Build SPA with Vue Router 2.0
Takuya Tejima
 
Vue js 大型專案架構
Vue js 大型專案架構
Hina Chen
 
Javascript MVVM with Vue.JS
Javascript MVVM with Vue.JS
Eueung Mulyana
 
Vue js and Vue Material
Vue js and Vue Material
Eueung Mulyana
 
Vuejs for Angular developers
Vuejs for Angular developers
Mikhail Kuznetcov
 
Vue.js
Vue.js
BADR
 
Introduction to VueJS & Vuex
Introduction to VueJS & Vuex
Bernd Alter
 
Modern frontend development with VueJs
Modern frontend development with VueJs
Tudor Barbu
 
An introduction to Vue.js
An introduction to Vue.js
Pagepro
 
第一次用 Vue.js 就愛上 [改]
第一次用 Vue.js 就愛上 [改]
Kuro Hsu
 
Vue Introduction
Vue Introduction
Elad Gasner
 

Similar to Scalable Front-end Development with Vue.JS (20)

What is Vuejs.pptx
What is Vuejs.pptx
NhnHVn2
 
Building a Single Page Application with VueJS
Building a Single Page Application with VueJS
danpastori
 
Intro to Vue
Intro to Vue
Isatu Conteh
 
Basics of Vue.js 2019
Basics of Vue.js 2019
Paul Bele
 
Why do JavaScript enthusiast think of Vue.js for building real-time web appli...
Why do JavaScript enthusiast think of Vue.js for building real-time web appli...
Katy Slemon
 
Introduction to Vue.js DevStaff Meetup 13.02
Introduction to Vue.js DevStaff Meetup 13.02
Paul Bele
 
Intro to VueJS Workshop
Intro to VueJS Workshop
Rafael Casuso Romate
 
VueJS Best Practices
VueJS Best Practices
Fatih Acet
 
What is Vue.js in Software Development.docx.pdf
What is Vue.js in Software Development.docx.pdf
MPIRIC Software
 
Progressive Javascript: Why React when you can Vue?
Progressive Javascript: Why React when you can Vue?
Sonal Raj
 
Why Choose Vue.js For Web Development Projects.pptx
Why Choose Vue.js For Web Development Projects.pptx
Scala Code
 
Vue.js Use Cases
Vue.js Use Cases
GlobalLogic Ukraine
 
Bouhamed vuejs-meetup-tecos
Bouhamed vuejs-meetup-tecos
TECOS
 
VueJS in Action
VueJS in Action
Rafael Casuso Romate
 
Production Ready Vue Apps With Nuxt.js
Production Ready Vue Apps With Nuxt.js
SnirShechter
 
The Characteristics of a Successful SPA
The Characteristics of a Successful SPA
Gil Fink
 
Pain Free Frontend Development
Pain Free Frontend Development
Vanessa Böhner
 
Performance optimization of vue.js apps with modern js
Performance optimization of vue.js apps with modern js
Filip Rakowski
 
VueJs Workshop
VueJs Workshop
Unfold UI
 
Introduction to web application development with Vue (for absolute beginners)...
Introduction to web application development with Vue (for absolute beginners)...
Lucas Jellema
 
What is Vuejs.pptx
What is Vuejs.pptx
NhnHVn2
 
Building a Single Page Application with VueJS
Building a Single Page Application with VueJS
danpastori
 
Basics of Vue.js 2019
Basics of Vue.js 2019
Paul Bele
 
Why do JavaScript enthusiast think of Vue.js for building real-time web appli...
Why do JavaScript enthusiast think of Vue.js for building real-time web appli...
Katy Slemon
 
Introduction to Vue.js DevStaff Meetup 13.02
Introduction to Vue.js DevStaff Meetup 13.02
Paul Bele
 
VueJS Best Practices
VueJS Best Practices
Fatih Acet
 
What is Vue.js in Software Development.docx.pdf
What is Vue.js in Software Development.docx.pdf
MPIRIC Software
 
Progressive Javascript: Why React when you can Vue?
Progressive Javascript: Why React when you can Vue?
Sonal Raj
 
Why Choose Vue.js For Web Development Projects.pptx
Why Choose Vue.js For Web Development Projects.pptx
Scala Code
 
Bouhamed vuejs-meetup-tecos
Bouhamed vuejs-meetup-tecos
TECOS
 
Production Ready Vue Apps With Nuxt.js
Production Ready Vue Apps With Nuxt.js
SnirShechter
 
The Characteristics of a Successful SPA
The Characteristics of a Successful SPA
Gil Fink
 
Pain Free Frontend Development
Pain Free Frontend Development
Vanessa Böhner
 
Performance optimization of vue.js apps with modern js
Performance optimization of vue.js apps with modern js
Filip Rakowski
 
VueJs Workshop
VueJs Workshop
Unfold UI
 
Introduction to web application development with Vue (for absolute beginners)...
Introduction to web application development with Vue (for absolute beginners)...
Lucas Jellema
 
Ad

Recently uploaded (20)

4th International Conference on Computer Science and Information Technology (...
4th International Conference on Computer Science and Information Technology (...
ijait
 
362 Alec Data Center Solutions-Slysium Data Center-AUH-Adaptaflex.pdf
362 Alec Data Center Solutions-Slysium Data Center-AUH-Adaptaflex.pdf
djiceramil
 
Water demand - Types , variations and WDS
Water demand - Types , variations and WDS
dhanashree78
 
SEW make Brake BE05 – BE30 Brake – Repair Kit
SEW make Brake BE05 – BE30 Brake – Repair Kit
projectultramechanix
 
Week 6- PC HARDWARE AND MAINTENANCE-THEORY.pptx
Week 6- PC HARDWARE AND MAINTENANCE-THEORY.pptx
dayananda54
 
3. What is the principles of Teamwork_Module_V1.0.ppt
3. What is the principles of Teamwork_Module_V1.0.ppt
engaash9
 
Impurities of Water and their Significance.pptx
Impurities of Water and their Significance.pptx
dhanashree78
 
22PCOAM16 _ML_Unit 3 Notes & Question bank
22PCOAM16 _ML_Unit 3 Notes & Question bank
Guru Nanak Technical Institutions
 
Center Enamel can Provide Aluminum Dome Roofs for diesel tank.docx
Center Enamel can Provide Aluminum Dome Roofs for diesel tank.docx
CenterEnamel
 
NALCO Green Anode Plant,Compositions of CPC,Pitch
NALCO Green Anode Plant,Compositions of CPC,Pitch
arpitprachi123
 
Engineering Mechanics Introduction and its Application
Engineering Mechanics Introduction and its Application
Sakthivel M
 
362 Alec Data Center Solutions-Slysium Data Center-AUH-Adaptaflex.pdf
362 Alec Data Center Solutions-Slysium Data Center-AUH-Adaptaflex.pdf
djiceramil
 
ACEP Magazine Fifth Edition on 5june2025
ACEP Magazine Fifth Edition on 5june2025
Rahul
 
362 Alec Data Center Solutions-Slysium Data Center-AUH-Adaptaflex.pdf
362 Alec Data Center Solutions-Slysium Data Center-AUH-Adaptaflex.pdf
djiceramil
 
COMPOSITE COLUMN IN STEEL CONCRETE COMPOSITES.ppt
COMPOSITE COLUMN IN STEEL CONCRETE COMPOSITES.ppt
ravicivil
 
Structural Design for Residential-to-Restaurant Conversion
Structural Design for Residential-to-Restaurant Conversion
DanielRoman285499
 
chemistry investigatory project for class 12
chemistry investigatory project for class 12
Susis10
 
OCS Group SG - HPHT Well Design and Operation - SN.pdf
OCS Group SG - HPHT Well Design and Operation - SN.pdf
Muanisa Waras
 
Rearchitecturing a 9-year-old legacy Laravel application.pdf
Rearchitecturing a 9-year-old legacy Laravel application.pdf
Takumi Amitani
 
362 Alec Data Center Solutions-Slysium Data Center-AUH-Glands & Lugs, Simplex...
362 Alec Data Center Solutions-Slysium Data Center-AUH-Glands & Lugs, Simplex...
djiceramil
 
4th International Conference on Computer Science and Information Technology (...
4th International Conference on Computer Science and Information Technology (...
ijait
 
362 Alec Data Center Solutions-Slysium Data Center-AUH-Adaptaflex.pdf
362 Alec Data Center Solutions-Slysium Data Center-AUH-Adaptaflex.pdf
djiceramil
 
Water demand - Types , variations and WDS
Water demand - Types , variations and WDS
dhanashree78
 
SEW make Brake BE05 – BE30 Brake – Repair Kit
SEW make Brake BE05 – BE30 Brake – Repair Kit
projectultramechanix
 
Week 6- PC HARDWARE AND MAINTENANCE-THEORY.pptx
Week 6- PC HARDWARE AND MAINTENANCE-THEORY.pptx
dayananda54
 
3. What is the principles of Teamwork_Module_V1.0.ppt
3. What is the principles of Teamwork_Module_V1.0.ppt
engaash9
 
Impurities of Water and their Significance.pptx
Impurities of Water and their Significance.pptx
dhanashree78
 
Center Enamel can Provide Aluminum Dome Roofs for diesel tank.docx
Center Enamel can Provide Aluminum Dome Roofs for diesel tank.docx
CenterEnamel
 
NALCO Green Anode Plant,Compositions of CPC,Pitch
NALCO Green Anode Plant,Compositions of CPC,Pitch
arpitprachi123
 
Engineering Mechanics Introduction and its Application
Engineering Mechanics Introduction and its Application
Sakthivel M
 
362 Alec Data Center Solutions-Slysium Data Center-AUH-Adaptaflex.pdf
362 Alec Data Center Solutions-Slysium Data Center-AUH-Adaptaflex.pdf
djiceramil
 
ACEP Magazine Fifth Edition on 5june2025
ACEP Magazine Fifth Edition on 5june2025
Rahul
 
362 Alec Data Center Solutions-Slysium Data Center-AUH-Adaptaflex.pdf
362 Alec Data Center Solutions-Slysium Data Center-AUH-Adaptaflex.pdf
djiceramil
 
COMPOSITE COLUMN IN STEEL CONCRETE COMPOSITES.ppt
COMPOSITE COLUMN IN STEEL CONCRETE COMPOSITES.ppt
ravicivil
 
Structural Design for Residential-to-Restaurant Conversion
Structural Design for Residential-to-Restaurant Conversion
DanielRoman285499
 
chemistry investigatory project for class 12
chemistry investigatory project for class 12
Susis10
 
OCS Group SG - HPHT Well Design and Operation - SN.pdf
OCS Group SG - HPHT Well Design and Operation - SN.pdf
Muanisa Waras
 
Rearchitecturing a 9-year-old legacy Laravel application.pdf
Rearchitecturing a 9-year-old legacy Laravel application.pdf
Takumi Amitani
 
362 Alec Data Center Solutions-Slysium Data Center-AUH-Glands & Lugs, Simplex...
362 Alec Data Center Solutions-Slysium Data Center-AUH-Glands & Lugs, Simplex...
djiceramil
 
Ad

Scalable Front-end Development with Vue.JS