SlideShare a Scribd company logo
JavaScript MV* Framework -
Making the Right Choice
by @sheiko
Who’s the dude?
I’m Dmitry Sheiko, a web-developer, blogger,
open source contributor.
http://dsheiko.com
@sheiko
https://github.com/dsheiko
What do I need a framework for?
• Abstractions (separation of concerns)
• Implicit conventions
• Code reusability
• Data Binding
• Widgets Library
What framework do I need?
MVC
Backbone
MVP
MVVM
AngularJS
Ember.js
Dojo
YUI
Agility.js
KnockoutJS
CanJS
Maria
Polymer
React
cujoJS Montage
Sammy.js
Stapes
Epitome
DUEL
Kendo UIPureMVC
Olives
PlastronJS
Dijon
rAppid.js
DeftJS + ExtJS
SAPUI5
Exoskeleton
Atma.js
Ractive.js
ComponentJS
Vue.js
Big Three
AngularJS
Backbone
Ember.js
How they implement MV*
bit.ly/1p24xgq
Collection
Model
Template
Router
Controller
Scope View
AngularJS
Backbone
Ember.js
How active developers community
Backbone
Stars: 18 264
Forks: 4 066
Open issues: 26
Closed issues: 3 151
Ember.js
Stars: 10 442
Forks: 2 249
Open issues: 220
Closed issues: 4 788
AngularJS
Stars: 24 958
Forks: 8 635
Open issues: 1 117
Closed issues: 6 704
via Github
13.06.2014
How good FAQ support
Backbone
Questions: 15 191
Answered: 9 193
60%
Avg answers per question: 2.24
Ember.js
Questions: 18 243
Answered: 11 120
61%
Avg answers per question: 2.40
AngularJS
Questions: 40 312
Answered: 22 382
55%
Avg answers per question: 2.30
via StackExchange
13.06.2014
The hidden part of the iceberg
AngularJS
Logical LOC: 6 748
Mean parameter count: 1.5
Cyclomatic complexity: 1 548
Cyclomatic complexity
density: 23%
Maintainability index: 113
Production build: 108K
Ember.js*
Logical LOC: 43 390
Mean parameter count: 1.2
Cyclomatic complexity: 2 543
Cyclomatic complexity
density: 17%
Maintainability index: 113
Production build: 276K
Backbone*
Logical LOC: 965
Mean parameter count: 1.3
Cyclomatic complexity: 275
Cyclomatic complexity
density: 28%
Maintainability index: 108
Production build: 20K
* without dependencies
Wonna really be in control of
your own code?
You have to know then exactly
what the framework does
Ember.js? AngularJS?
Unlikely…
Backbone is our hero!
http://backbonejs.org/docs/backbone.html
What about dependencies?
Do we need them?
Backbone
jQuery Underscore
Not really!
jQuery Underscore
Backbone4
Exoskeleton
Exoskeleton is an optimized Backbone
Faster
Lightweight
Dependencies
optional
http://exosjs.com
Custom builds
Backbone
drop-in
replacement
What about legacy browsers?
https://github.com/es-shims/es5-shim
An example?
TODO MVC
http://bit.ly/T0oREh
Exoskeleton + CommonJS Compiler
http://bit.ly/1lr1R7Z
Thank you!
My credits to www.flaticon.com for
these amazing free vector icons and
surely to Paul Miller and Adam Krebs
for Exoskeleton

More Related Content

PDF
JS Framework Comparison - An infographic
PPTX
Javascript Frameworks Comparison - Angular, Knockout, Ember and Backbone
PDF
Choosing the best JavaScript framework/library/toolkit
PPTX
Mvvm knockout vs angular
PPTX
AngularJS vs React JS vs Node JS: Which is Best For Web Development ?
PPTX
PDF
On Selecting JavaScript Frameworks (Women Who Code 10/15)
PDF
Transforming Front-End Disaster Code™ Into A Maintainable Masterpiece
JS Framework Comparison - An infographic
Javascript Frameworks Comparison - Angular, Knockout, Ember and Backbone
Choosing the best JavaScript framework/library/toolkit
Mvvm knockout vs angular
AngularJS vs React JS vs Node JS: Which is Best For Web Development ?
On Selecting JavaScript Frameworks (Women Who Code 10/15)
Transforming Front-End Disaster Code™ Into A Maintainable Masterpiece

What's hot (20)

PDF
Going Node.js at Netflix
PPTX
jQuery Conference 2012 keynote
PDF
jQuery Keynote - Fall 2010
PDF
jQuery Chicago 2014 - Next-generation JavaScript Testing
PDF
Node PDX: Intro to Sails.js
PPTX
Automated perf optimization - jQuery Conference
PDF
Testing Angular 2 Applications - Rich Web 2016
PDF
Testing Mobile JavaScript
PDF
Atomic Design with Next.js
PDF
Angular2 + AWS Lambdaでサーバサイドレンダリングしてみた
PPT
Javascript Frameworks
PPTX
Lazy angular w/ webpack
PPTX
Javascript Frameworks Comparison
KEY
SlickGrid Touch: Making complex JavaScript widgets work on mobile devices
PDF
Testing Angular 2 Applications - HTML5 Denver 2016
PDF
Wulin kungfu final
PDF
The Onion
PDF
Get Hip with JHipster: Spring Boot + AngularJS + Bootstrap - GeekOut 2016
PDF
Avoiding Common Pitfalls in Ember.js
PPTX
Frontend architecture design for large(r) team final
Going Node.js at Netflix
jQuery Conference 2012 keynote
jQuery Keynote - Fall 2010
jQuery Chicago 2014 - Next-generation JavaScript Testing
Node PDX: Intro to Sails.js
Automated perf optimization - jQuery Conference
Testing Angular 2 Applications - Rich Web 2016
Testing Mobile JavaScript
Atomic Design with Next.js
Angular2 + AWS Lambdaでサーバサイドレンダリングしてみた
Javascript Frameworks
Lazy angular w/ webpack
Javascript Frameworks Comparison
SlickGrid Touch: Making complex JavaScript widgets work on mobile devices
Testing Angular 2 Applications - HTML5 Denver 2016
Wulin kungfu final
The Onion
Get Hip with JHipster: Spring Boot + AngularJS + Bootstrap - GeekOut 2016
Avoiding Common Pitfalls in Ember.js
Frontend architecture design for large(r) team final
Ad

Viewers also liked (11)

PPTX
Modern JavaScript Talk
KEY
Plack at OSCON 2010
PDF
Why SOLID matters - even for JavaScript
PPTX
Introduction to Underscore.js
PDF
MVC Revivial on the Web
PPTX
Latest Javascript MVC & Front End Frameworks 2017
PDF
Marionette: the Backbone framework
PPTX
Vuejs Angularjs e Reactjs. Veja as diferenças de cada framework!
PDF
Comparing JVM Web Frameworks - February 2014
PPTX
Rethinking Best Practices
PDF
Comparing Hot JavaScript Frameworks: AngularJS, Ember.js and React.js - Sprin...
Modern JavaScript Talk
Plack at OSCON 2010
Why SOLID matters - even for JavaScript
Introduction to Underscore.js
MVC Revivial on the Web
Latest Javascript MVC & Front End Frameworks 2017
Marionette: the Backbone framework
Vuejs Angularjs e Reactjs. Veja as diferenças de cada framework!
Comparing JVM Web Frameworks - February 2014
Rethinking Best Practices
Comparing Hot JavaScript Frameworks: AngularJS, Ember.js and React.js - Sprin...
Ad

Similar to JavaScript MV* Framework - Making the Right Choice (8)

ODP
JavaScript frameworks overview + AngularJS
PDF
Choosing the right JavaScript library/framework/toolkit for our project
PPTX
Javascript mvc
PPTX
MVC & backbone.js
PPTX
Get Started with JavaScript Frameworks
PPTX
JavaScript MVC Frameworks: Backbone, Ember and Angular JS
PPTX
Choosing a JavaScript Framework
PDF
AngularJS - A Powerful Framework For Web Applications
JavaScript frameworks overview + AngularJS
Choosing the right JavaScript library/framework/toolkit for our project
Javascript mvc
MVC & backbone.js
Get Started with JavaScript Frameworks
JavaScript MVC Frameworks: Backbone, Ember and Angular JS
Choosing a JavaScript Framework
AngularJS - A Powerful Framework For Web Applications

More from Dmitry Sheiko (7)

PPTX
The Flavor of TypeScript
PPTX
Writing Scalable and Maintainable CSS
PDF
Tooling JavaScript to ensure consistency in coding style
PDF
Modular JavaScript with CommonJS Compiler
PDF
TypeScript Introduction
PDF
A Quick Start - Version Control with Git
PPTX
Bringing classical OOP into JavaScript
The Flavor of TypeScript
Writing Scalable and Maintainable CSS
Tooling JavaScript to ensure consistency in coding style
Modular JavaScript with CommonJS Compiler
TypeScript Introduction
A Quick Start - Version Control with Git
Bringing classical OOP into JavaScript

Recently uploaded (20)

PPTX
Job_Card_System_Styled_lorem_ipsum_.pptx
PPTX
Digital Literacy And Online Safety on internet
PPTX
Introduction about ICD -10 and ICD11 on 5.8.25.pptx
PPTX
June-4-Sermon-Powerpoint.pptx USE THIS FOR YOUR MOTIVATION
PPTX
PptxGenJS_Demo_Chart_20250317130215833.pptx
PDF
RPKI Status Update, presented by Makito Lay at IDNOG 10
PDF
Triggering QUIC, presented by Geoff Huston at IETF 123
PPTX
introduction about ICD -10 & ICD-11 ppt.pptx
PPTX
Internet___Basics___Styled_ presentation
PPTX
international classification of diseases ICD-10 review PPT.pptx
DOCX
Unit-3 cyber security network security of internet system
PDF
Cloud-Scale Log Monitoring _ Datadog.pdf
PPTX
SAP Ariba Sourcing PPT for learning material
PDF
Paper PDF World Game (s) Great Redesign.pdf
PDF
The New Creative Director: How AI Tools for Social Media Content Creation Are...
PDF
Automated vs Manual WooCommerce to Shopify Migration_ Pros & Cons.pdf
PPTX
522797556-Unit-2-Temperature-measurement-1-1.pptx
PDF
Decoding a Decade: 10 Years of Applied CTI Discipline
PPTX
Introuction about ICD -10 and ICD-11 PPT.pptx
PDF
Unit-1 introduction to cyber security discuss about how to secure a system
Job_Card_System_Styled_lorem_ipsum_.pptx
Digital Literacy And Online Safety on internet
Introduction about ICD -10 and ICD11 on 5.8.25.pptx
June-4-Sermon-Powerpoint.pptx USE THIS FOR YOUR MOTIVATION
PptxGenJS_Demo_Chart_20250317130215833.pptx
RPKI Status Update, presented by Makito Lay at IDNOG 10
Triggering QUIC, presented by Geoff Huston at IETF 123
introduction about ICD -10 & ICD-11 ppt.pptx
Internet___Basics___Styled_ presentation
international classification of diseases ICD-10 review PPT.pptx
Unit-3 cyber security network security of internet system
Cloud-Scale Log Monitoring _ Datadog.pdf
SAP Ariba Sourcing PPT for learning material
Paper PDF World Game (s) Great Redesign.pdf
The New Creative Director: How AI Tools for Social Media Content Creation Are...
Automated vs Manual WooCommerce to Shopify Migration_ Pros & Cons.pdf
522797556-Unit-2-Temperature-measurement-1-1.pptx
Decoding a Decade: 10 Years of Applied CTI Discipline
Introuction about ICD -10 and ICD-11 PPT.pptx
Unit-1 introduction to cyber security discuss about how to secure a system

JavaScript MV* Framework - Making the Right Choice

  • 1. JavaScript MV* Framework - Making the Right Choice by @sheiko
  • 2. Who’s the dude? I’m Dmitry Sheiko, a web-developer, blogger, open source contributor. http://dsheiko.com @sheiko https://github.com/dsheiko
  • 3. What do I need a framework for? • Abstractions (separation of concerns) • Implicit conventions • Code reusability • Data Binding • Widgets Library
  • 4. What framework do I need? MVC Backbone MVP MVVM AngularJS Ember.js Dojo YUI Agility.js KnockoutJS CanJS Maria Polymer React cujoJS Montage Sammy.js Stapes Epitome DUEL Kendo UIPureMVC Olives PlastronJS Dijon rAppid.js DeftJS + ExtJS SAPUI5 Exoskeleton Atma.js Ractive.js ComponentJS Vue.js
  • 6. How they implement MV* bit.ly/1p24xgq Collection Model Template Router Controller Scope View AngularJS Backbone Ember.js
  • 7. How active developers community Backbone Stars: 18 264 Forks: 4 066 Open issues: 26 Closed issues: 3 151 Ember.js Stars: 10 442 Forks: 2 249 Open issues: 220 Closed issues: 4 788 AngularJS Stars: 24 958 Forks: 8 635 Open issues: 1 117 Closed issues: 6 704 via Github 13.06.2014
  • 8. How good FAQ support Backbone Questions: 15 191 Answered: 9 193 60% Avg answers per question: 2.24 Ember.js Questions: 18 243 Answered: 11 120 61% Avg answers per question: 2.40 AngularJS Questions: 40 312 Answered: 22 382 55% Avg answers per question: 2.30 via StackExchange 13.06.2014
  • 9. The hidden part of the iceberg AngularJS Logical LOC: 6 748 Mean parameter count: 1.5 Cyclomatic complexity: 1 548 Cyclomatic complexity density: 23% Maintainability index: 113 Production build: 108K Ember.js* Logical LOC: 43 390 Mean parameter count: 1.2 Cyclomatic complexity: 2 543 Cyclomatic complexity density: 17% Maintainability index: 113 Production build: 276K Backbone* Logical LOC: 965 Mean parameter count: 1.3 Cyclomatic complexity: 275 Cyclomatic complexity density: 28% Maintainability index: 108 Production build: 20K * without dependencies
  • 10. Wonna really be in control of your own code?
  • 11. You have to know then exactly what the framework does
  • 13. Backbone is our hero! http://backbonejs.org/docs/backbone.html
  • 14. What about dependencies? Do we need them? Backbone jQuery Underscore
  • 16. Exoskeleton is an optimized Backbone Faster Lightweight Dependencies optional http://exosjs.com Custom builds Backbone drop-in replacement
  • 17. What about legacy browsers? https://github.com/es-shims/es5-shim
  • 18. An example? TODO MVC http://bit.ly/T0oREh Exoskeleton + CommonJS Compiler http://bit.ly/1lr1R7Z
  • 19. Thank you! My credits to www.flaticon.com for these amazing free vector icons and surely to Paul Miller and Adam Krebs for Exoskeleton