SlideShare a Scribd company logo
Front End Workshops
IX. MVC & Backbone.js
Andrés Lamilla
alamilla@visual-engin.com
Overview
● MVC
● BackboneJS
● MarionetteJS
● Marionette Inspector
● Examples
MVC
● Architectural design pattern
● Encourages improved application organization
through a separation of concerns
● Isolation of business data (models) from user
interfaces (views) and logic (controllers)
MVC
MVC separates the concerns in an application into
three parts:
● Models represent the domain-specific knowledge
and data in an application. Models can notify
observers when their state changes.
● Views typically constitute the user interface in an
application (templates). They observe models, but
don’t directly communicate with them.
● Controllers handle input (clicks or user actions) and
update models.
Smalltalk-80 MVC
Trygve Reenskaug designed this pattern while he
was working on Smalltalk-80 (1979).
His idea was to separate the application logic from
the user interface.
Smalltalk-80 MVC
● model ignorant of the user interface (views and
controllers)
● Presentation was taken care of by the view and
the controller
● The controller’s role in this pair was handling
user input
● The Observer pattern was used to update the
view whenever the model changed
MVC-like in Ruby on Rails (RoR)
Although there’s a clear separation of concerns that is
MVC-like in Rails, it is actually using a different pattern
called Model2.
Server-side MVC
Client-Side MVC
BackboneJS
BackboneJS
● It is a lightweight library designed for
developing single-page web applications.
● Was created by Jeremy Ashkenas, who is also
known for CoffeeScript and Underscore.js
Used by
Used by
Used by
Models
Models (initialize)
Models (Default values)
Models (Get)
Models (Set)
Models (Listening for Changes)
Views
Collections
Models (RESTful)
Routers
BackboneJS
BackboneJS
● Backbone is not a complete framework. It gives
us the core constructs that we need to build
small to midsize apps.
● There are several frameworks build on top of
Backbone that are suitable for large applications.
Chaplin, Marionette and Thorax are the most
used.
MarionetteJS
● It is a composite application library that aims to simplify
the construction of large-scale applications
● Allows you to scale applications out with modular,
event-driven architecture
● Reduces boilerplate for views, with specialized view
types
● Allows you to compose your application’s visuals at
runtime, with region and layout ...
● Includes built-in memory management and zombie
killing in views, regions, and layouts
● Provides built-in event cleanup with the EventBinder
Reducing Boilerplate with Marionette
Memory Management with Marionette
Memory Management with Marionette
Memory Management with Marionette
Marionette’s views provide a
close event, in which the
event bindings that are set
up with the listenTo are
automatically removed
Memory Management with Marionette
Marionette Inspector
Debug Marionette Apps:
http://marionettejs.com/inspector/
Test app:
http://www.marionettewires.com/#colors
Examples
http://develop.mostsearchedcelebrity.com
user: test@test.com
pass: 123
Code: https://github.com/alamillac/mostWanted
Workshop 9: BackboneJS y patrones MVC

More Related Content

What's hot (20)

PDF
Introduction to AngularJS
Jussi Pohjolainen
 
PDF
AngularJS introduction
Tania Gonzales
 
PDF
Advanced Tips & Tricks for using Angular JS
Simon Guest
 
PPTX
Angular JS - Introduction
Sagar Acharya
 
PPTX
Introduction to Angularjs
Manish Shekhawat
 
PPTX
AngularJS Beginners Workshop
Sathish VJ
 
ODP
Angularjs
Vincenzo Ferrari
 
PDF
Angularjs - lazy loading techniques
Nir Kaufman
 
PDF
Introduction of angular js
Tamer Solieman
 
PPTX
Single Page Applications with AngularJS 2.0
Sumanth Chinthagunta
 
PPTX
Why angular js Framework
Sakthi Bro
 
PPTX
AngularJS Best Practices
Narek Mamikonyan
 
PPTX
Angularjs Basics
Anuradha Bandara
 
PPTX
Practical AngularJS
Wei Ru
 
PPTX
AngularJS intro
dizabl
 
PPTX
Angular Lazy Loading and Resolve (Route Resolver)
Squash Apps Pvt Ltd
 
PPTX
AngularJS - Architecture decisions in a large project 
Elad Hirsch
 
PDF
An Introduction To Testing In AngularJS Applications
Rohan Chandane
 
PPTX
5 angularjs features
Alexey (Mr_Mig) Migutsky
 
PDF
AngularJS 101 - Everything you need to know to get started
Stéphane Bégaudeau
 
Introduction to AngularJS
Jussi Pohjolainen
 
AngularJS introduction
Tania Gonzales
 
Advanced Tips & Tricks for using Angular JS
Simon Guest
 
Angular JS - Introduction
Sagar Acharya
 
Introduction to Angularjs
Manish Shekhawat
 
AngularJS Beginners Workshop
Sathish VJ
 
Angularjs
Vincenzo Ferrari
 
Angularjs - lazy loading techniques
Nir Kaufman
 
Introduction of angular js
Tamer Solieman
 
Single Page Applications with AngularJS 2.0
Sumanth Chinthagunta
 
Why angular js Framework
Sakthi Bro
 
AngularJS Best Practices
Narek Mamikonyan
 
Angularjs Basics
Anuradha Bandara
 
Practical AngularJS
Wei Ru
 
AngularJS intro
dizabl
 
Angular Lazy Loading and Resolve (Route Resolver)
Squash Apps Pvt Ltd
 
AngularJS - Architecture decisions in a large project 
Elad Hirsch
 
An Introduction To Testing In AngularJS Applications
Rohan Chandane
 
5 angularjs features
Alexey (Mr_Mig) Migutsky
 
AngularJS 101 - Everything you need to know to get started
Stéphane Bégaudeau
 

Viewers also liked (13)

PDF
Workshop 10: ECMAScript 6
Visual Engineering
 
PDF
Workshop 5: JavaScript testing
Visual Engineering
 
PDF
Workshop 8: Templating: Handlebars, DustJS
Visual Engineering
 
PDF
Workshop 14: AngularJS Parte III
Visual Engineering
 
PPSX
03 09-2010 - pp - promoção
Fernando
 
PDF
Workshop 15: Ionic framework
Visual Engineering
 
PDF
Workshop 7: Single Page Applications
Visual Engineering
 
PPSX
Power point perumahan
rezaalfiansyah14
 
PDF
Workshop 12: AngularJS Parte I
Visual Engineering
 
PPTX
Persiapan proyek
Property
 
PDF
MEMULAI BISNIS PROPERTI, MENJADI MINI DEVELOPER
MZ Omar, ST
 
PDF
Presentasi
paktan1
 
PDF
Marketing Plan for Property
PT Mitra Shapphire Sejahtera
 
Workshop 10: ECMAScript 6
Visual Engineering
 
Workshop 5: JavaScript testing
Visual Engineering
 
Workshop 8: Templating: Handlebars, DustJS
Visual Engineering
 
Workshop 14: AngularJS Parte III
Visual Engineering
 
03 09-2010 - pp - promoção
Fernando
 
Workshop 15: Ionic framework
Visual Engineering
 
Workshop 7: Single Page Applications
Visual Engineering
 
Power point perumahan
rezaalfiansyah14
 
Workshop 12: AngularJS Parte I
Visual Engineering
 
Persiapan proyek
Property
 
MEMULAI BISNIS PROPERTI, MENJADI MINI DEVELOPER
MZ Omar, ST
 
Presentasi
paktan1
 
Marketing Plan for Property
PT Mitra Shapphire Sejahtera
 
Ad

Similar to Workshop 9: BackboneJS y patrones MVC (20)

PPTX
Single Page Application Development with backbone.js and Simple.Web
Chris Canal
 
PPTX
MVC & backbone.js
Mohammed Arif
 
PPTX
Marionette talk 2016
Kseniya Redunova
 
PPTX
Give your web apps some backbone
RTigger
 
PPTX
Planbox Backbone MVC
Acquisio
 
PPTX
MV* presentation frameworks in Javascript: en garde, pret, allez!
Roberto Messora
 
PPSX
Introduction to backbone_js
Mohammed Saqib
 
PDF
Make your Backbone Application dance
Nicholas Valbusa
 
PPTX
Javascript for Wep Apps
Michael Puckett
 
PPTX
Backbone/Marionette recap [2015]
Andrii Lundiak
 
PDF
Rp 6 session 2 naresh bhatia
sapientindia
 
PDF
Backbone.js slides
Ambert Ho
 
PDF
Developing Backbonejs Applications Early Release Addy Osmani
littelenkali
 
PPTX
Building SPA’s (Single Page App) with Backbone.js
Microsoft Developer Network (MSDN) - Belgium and Luxembourg
 
PPTX
Backbone.js
VO Tho
 
PPTX
Front-end rich JavaScript application creation (Backbone.js)
Oleksii Prohonnyi
 
PDF
Intro to BackboneJS + Intermediate Javascript
Andrew Lovett-Barron
 
PDF
Instant download Developing Backbone js Applications Addy Osmani pdf all chapter
dinetvenitja
 
PDF
Developing Backbone js Applications Addy Osmani
leitaduminy
 
PPTX
Backbone
Sayed Ahmed
 
Single Page Application Development with backbone.js and Simple.Web
Chris Canal
 
MVC & backbone.js
Mohammed Arif
 
Marionette talk 2016
Kseniya Redunova
 
Give your web apps some backbone
RTigger
 
Planbox Backbone MVC
Acquisio
 
MV* presentation frameworks in Javascript: en garde, pret, allez!
Roberto Messora
 
Introduction to backbone_js
Mohammed Saqib
 
Make your Backbone Application dance
Nicholas Valbusa
 
Javascript for Wep Apps
Michael Puckett
 
Backbone/Marionette recap [2015]
Andrii Lundiak
 
Rp 6 session 2 naresh bhatia
sapientindia
 
Backbone.js slides
Ambert Ho
 
Developing Backbonejs Applications Early Release Addy Osmani
littelenkali
 
Building SPA’s (Single Page App) with Backbone.js
Microsoft Developer Network (MSDN) - Belgium and Luxembourg
 
Backbone.js
VO Tho
 
Front-end rich JavaScript application creation (Backbone.js)
Oleksii Prohonnyi
 
Intro to BackboneJS + Intermediate Javascript
Andrew Lovett-Barron
 
Instant download Developing Backbone js Applications Addy Osmani pdf all chapter
dinetvenitja
 
Developing Backbone js Applications Addy Osmani
leitaduminy
 
Backbone
Sayed Ahmed
 
Ad

More from Visual Engineering (20)

PDF
Workshop 27: Isomorphic web apps with ReactJS
Visual Engineering
 
PDF
Workshop iOS 4: Closures, generics & operators
Visual Engineering
 
PDF
Workshop iOS 3: Testing, protocolos y extensiones
Visual Engineering
 
PDF
Workshop iOS 2: Swift - Structures
Visual Engineering
 
PDF
Workhop iOS 1: Fundamentos de Swift
Visual Engineering
 
PDF
Workshop 26: React Native - The Native Side
Visual Engineering
 
PDF
Workshop 25: React Native - Components
Visual Engineering
 
PDF
Workshop 24: React Native Introduction
Visual Engineering
 
PDF
Workshop 23: ReactJS, React & Redux testing
Visual Engineering
 
PDF
Workshop 22: ReactJS Redux Advanced
Visual Engineering
 
PDF
Workshop 21: React Router
Visual Engineering
 
PDF
Workshop 20: ReactJS Part II Flux Pattern & Redux
Visual Engineering
 
PDF
Workshop 19: ReactJS Introduction
Visual Engineering
 
PDF
Workshop 18: CSS Animations & cool effects
Visual Engineering
 
PDF
Workshop 17: EmberJS parte II
Visual Engineering
 
PDF
Workshop 11: Trendy web designs & prototyping
Visual Engineering
 
PDF
Workshop 6: Designer tools
Visual Engineering
 
PDF
Workshop 4: NodeJS. Express Framework & MongoDB.
Visual Engineering
 
PDF
Workshop 3: JavaScript build tools
Visual Engineering
 
PDF
Workshop 2: JavaScript Design Patterns
Visual Engineering
 
Workshop 27: Isomorphic web apps with ReactJS
Visual Engineering
 
Workshop iOS 4: Closures, generics & operators
Visual Engineering
 
Workshop iOS 3: Testing, protocolos y extensiones
Visual Engineering
 
Workshop iOS 2: Swift - Structures
Visual Engineering
 
Workhop iOS 1: Fundamentos de Swift
Visual Engineering
 
Workshop 26: React Native - The Native Side
Visual Engineering
 
Workshop 25: React Native - Components
Visual Engineering
 
Workshop 24: React Native Introduction
Visual Engineering
 
Workshop 23: ReactJS, React & Redux testing
Visual Engineering
 
Workshop 22: ReactJS Redux Advanced
Visual Engineering
 
Workshop 21: React Router
Visual Engineering
 
Workshop 20: ReactJS Part II Flux Pattern & Redux
Visual Engineering
 
Workshop 19: ReactJS Introduction
Visual Engineering
 
Workshop 18: CSS Animations & cool effects
Visual Engineering
 
Workshop 17: EmberJS parte II
Visual Engineering
 
Workshop 11: Trendy web designs & prototyping
Visual Engineering
 
Workshop 6: Designer tools
Visual Engineering
 
Workshop 4: NodeJS. Express Framework & MongoDB.
Visual Engineering
 
Workshop 3: JavaScript build tools
Visual Engineering
 
Workshop 2: JavaScript Design Patterns
Visual Engineering
 

Recently uploaded (20)

PPTX
Why Businesses Are Switching to Open Source Alternatives to Crystal Reports.pptx
Varsha Nayak
 
PDF
Thread In Android-Mastering Concurrency for Responsive Apps.pdf
Nabin Dhakal
 
PPTX
Homogeneity of Variance Test Options IBM SPSS Statistics Version 31.pptx
Version 1 Analytics
 
PPTX
Home Care Tools: Benefits, features and more
Third Rock Techkno
 
PDF
유니티에서 Burst Compiler+ThreadedJobs+SIMD 적용사례
Seongdae Kim
 
PDF
Automate Cybersecurity Tasks with Python
VICTOR MAESTRE RAMIREZ
 
PPTX
Empowering Asian Contributions: The Rise of Regional User Groups in Open Sour...
Shane Coughlan
 
PDF
SciPy 2025 - Packaging a Scientific Python Project
Henry Schreiner
 
PPTX
AEM User Group: India Chapter Kickoff Meeting
jennaf3
 
PDF
Alarm in Android-Scheduling Timed Tasks Using AlarmManager in Android.pdf
Nabin Dhakal
 
PDF
Online Queue Management System for Public Service Offices in Nepal [Focused i...
Rishab Acharya
 
PPTX
Hardware(Central Processing Unit ) CU and ALU
RizwanaKalsoom2
 
PDF
Generic or Specific? Making sensible software design decisions
Bert Jan Schrijver
 
PPTX
OpenChain @ OSS NA - In From the Cold: Open Source as Part of Mainstream Soft...
Shane Coughlan
 
PDF
Download Canva Pro 2025 PC Crack Full Latest Version
bashirkhan333g
 
PDF
MiniTool Partition Wizard 12.8 Crack License Key LATEST
hashhshs786
 
PDF
4K Video Downloader Plus Pro Crack for MacOS New Download 2025
bashirkhan333g
 
PDF
Open Chain Q2 Steering Committee Meeting - 2025-06-25
Shane Coughlan
 
PPTX
Agentic Automation: Build & Deploy Your First UiPath Agent
klpathrudu
 
PDF
Why Businesses Are Switching to Open Source Alternatives to Crystal Reports.pdf
Varsha Nayak
 
Why Businesses Are Switching to Open Source Alternatives to Crystal Reports.pptx
Varsha Nayak
 
Thread In Android-Mastering Concurrency for Responsive Apps.pdf
Nabin Dhakal
 
Homogeneity of Variance Test Options IBM SPSS Statistics Version 31.pptx
Version 1 Analytics
 
Home Care Tools: Benefits, features and more
Third Rock Techkno
 
유니티에서 Burst Compiler+ThreadedJobs+SIMD 적용사례
Seongdae Kim
 
Automate Cybersecurity Tasks with Python
VICTOR MAESTRE RAMIREZ
 
Empowering Asian Contributions: The Rise of Regional User Groups in Open Sour...
Shane Coughlan
 
SciPy 2025 - Packaging a Scientific Python Project
Henry Schreiner
 
AEM User Group: India Chapter Kickoff Meeting
jennaf3
 
Alarm in Android-Scheduling Timed Tasks Using AlarmManager in Android.pdf
Nabin Dhakal
 
Online Queue Management System for Public Service Offices in Nepal [Focused i...
Rishab Acharya
 
Hardware(Central Processing Unit ) CU and ALU
RizwanaKalsoom2
 
Generic or Specific? Making sensible software design decisions
Bert Jan Schrijver
 
OpenChain @ OSS NA - In From the Cold: Open Source as Part of Mainstream Soft...
Shane Coughlan
 
Download Canva Pro 2025 PC Crack Full Latest Version
bashirkhan333g
 
MiniTool Partition Wizard 12.8 Crack License Key LATEST
hashhshs786
 
4K Video Downloader Plus Pro Crack for MacOS New Download 2025
bashirkhan333g
 
Open Chain Q2 Steering Committee Meeting - 2025-06-25
Shane Coughlan
 
Agentic Automation: Build & Deploy Your First UiPath Agent
klpathrudu
 
Why Businesses Are Switching to Open Source Alternatives to Crystal Reports.pdf
Varsha Nayak
 

Workshop 9: BackboneJS y patrones MVC