SlideShare a Scribd company logo
Gran Sasso Science Institute
Ivano Malavolta
Backbone JS
Roadmap
• Why Backbone
• Events
• Models
• Collections
• Views
• Routers
• Summary
Why Backbone
We are buildingapps, not web sites
If your code is not structured:
• it is extremely easy that your web app becomes a
big mess of HTML + CSS + JavaScript
• maintainingeach part of your app asks for a
deep analysis of ALL its aspects (logic, presentation, etc.)
• you may waste a whole day due to a missing <
Why Backbone
Backbone gives you STRUCTURE
What we want to avoid
Imagine yourself trying to change
• how a movie should be rendered in your app
• the REST API providing info about movies
Why Backbone (1)
From the Backbone website...
manipulate
the DOM
lists
of models
represent
data
Why Backbone (2)
Additionally,Backbone provides also features for:
sync
for managing how to persist models (default is via REST)
events
for managing how data and control are exchanged within your app
router
for managing the interaction flow among views
Backbone in a nutshell
Who is using Backbone?
Roadmap
• Why Backbone
• Events
• Models
• Collections
• Views
• Routers
• Summary
Events
Any object communicates with other objects via events
It gives the object the ability to bind and trigger custom named events
It is extremely useful for exchanging data and control among objects
Events
Basically, each object can:
• listen to events
• trigger events
Events
Two types of events:
you define your own types of event
built-in
custom
Events API
object will react to the “alert” event
(the “off” function detaches the event)
event parameters
the “alert” event is
fired
Events API
Events methods:
on
object.on(event, callback, [context])
off
object.off([event], [callback], [context])
once
object.once(event, callback, [context])
trigger
object.trigger(event, [*args])
listenTo
object.listenTo(other, event, callback)
stopListening
object.stopListening([other], [event], [callback])
listenToOnce
object.listenToOnce(other, event, callback)
Events summary
Roadmap
• Why Backbone
• Events
• Models
• Collections
• Views
• Routers
• Summary
Models
Models represent your data
Each model represents a data type in your app, together with the logic surroundingit, like:
• persistence
• conversions
• validation
• computed properties
• access control
MVC: Notify their observers about
state using the Observer pattern
Models
You extend Backbone.Model with your domain-specific methods, and Model provides a basic set of
functionalityfor managing changes, like:
• getter and setter
• id
• constructor
• REST-based persistence
Example of model
custom method
setting an
attribute
event fired when
“color” changes
custom method
invocation
Model constructor and attributes
initialize()
it is triggered every time you create a new instance of a model
it works also for collections and views
it can take a JS object for setting also attributes
get() & set()
they are used to set and retrieve the value of certain attributes
defaults
a property named 'defaults' in your model declaration
Example
http://goo.gl/UOahsP
Model persistence
Backbone.sync
is the function that Backbone calls every time it attempts to read or save a model
By default, it uses Ajax to make a REST-ish request to a server
Resources represented
as JSON strings
Sync signature
sync(method, model, [options])
method
the CRUD method ("create“, "read“, "update", or "delete")
model
the model (or collection)to be synced
options
success and error callbacks, and all other jQuery request options
example of overriden sync:
http://bit.ly/KWdxNN
Sync returns a jQuery XMLHttpRequest (jqXHR) object
It implements the Promise
interface
Sync usage
Normally you will not use the sync method directly, you will do it implicitlywhen you call one of these
methods
Model
• fetch: gets the most up-to-date values of the model instance
• save: persists the model instance
• destroy: deletes the model instance
Collection
• fetch: gets all the models of the collection from the server
• create: creates a model, saves it to the server and adds it to the collection
Overriding sync
You can override it in order to use a different persistence strategy, such as:
• WebSockets
• Local Storage
• WebSQL
Backbone.sync is the default global function that all models use unless the models have a sync method
specifically set
Models summary
Roadmap
• Why Backbone
• Events
• Models
• Collections
• Views
• Routers
• Summary
Collections
Collections are ordered sets of models
You can:
• bind change events to be notified when any model in the collection has been modified
• listen for add and remove events
• fetch the collection from the server (or other persistence layers)
• find models or filter collections themeselves
The model attribute of a collection represents the kind of model that can be stored in it
Any event that is triggered on a model in a collection
will also be triggered on the collection directly
MVC: Notify their observers
about state using the Observer
pattern (same as models)
Collection example
http://goo.gl/UOahsP
Collections summary
Roadmap
• Why Backbone
• Events
• Models
• Collections
• Views
• Routers
• Summary
Views
Views represent and manage the visible parts of your application
They are also used to
• listen to user interaction events
• and react accordingly
views can be rendered at any time, and inserted into the DOM
you get high-performance UI rendering
with as few reflows and repaints as possible
MVC: a view observes a model, and
updates itself according to the state
of the model + manage user inputs
(it’s a controller, to this sense)
Interaction with the DOM
All views refer to a DOM element at all times
this.el is a reference to the DOM element, it is created from:
tagName
for example body, ul, span, img
className
class name of some element within the DOM
id
id of an element within the DOM
If none of them is specified,
this.el is an empty <div>
Rendering the view
The render() method is used to update the this.el element with the new HTML
The default implementation of render() is a no-op
à you have to override it to update this.el with your HTML code
Backbone is agnostic with respect to your code in render(), however...
you are STRONGLY encouraged to use a
JavaScript templating library here
View example
http://goo.gl/UOahsP
Interaction with the user
Events map
“event_name selector”: callback
Events callbacks
Views summary
Roadmap
• Why Backbone
• Events
• Models
• Collections
• Views
• Routers
• Summary
The router
Backbone.Router provides methods for routingclient-side pages,
and connecting them to actions and events
At a minimum, a router is composed of two main parts:
routes
an hash that pairs routes to actions
actions
JS functionstriggered when certain routes are navigated
It can be seen as the “implementation”
of a navigation model
Routing
Every router contains an hash that maps routes to functions on your router
URLs fragments can also contain dynamic data via Backbone-specific URL parts:
parameter (:param)
match a single URL component between slashes
splat (*fragment)
match any number of URL components
Routing
routes map
routing
functions
History
History serves as a global router to
1. handle hashchange events
2. match the appropriate route
3. trigger callbacks
You should never access it directly, you just need call Backbone.history.start() to begin
monitoringhashchange events, and dispatching routes in your app
Call Backbone.history.navigate(ROUTE_NAME, {trigger: true}); to activate a specific route
of the router
Technically, it uses the HTML5
History API to listen to its job
For older browsers, it uses URL hash
fragments as fallback
Router summary
Roadmap
• Why Backbone
• Events
• Models
• Collections
• Views
• Routers
• Summary
Classical workflow
1. You dig into JSON objects
2. Look up elements in the DOM
3. Update the HTML by hand
Backbone-based workflow
• You organize your interface into logical views backed by models
• Each view can be updated independently when the model changes,
without having to redraw the page
You can bind your view‘s
render() function to the
model‘s "change” event
à now everywhere that
model data is displayed in the
UI, it is always immediately up
to date
Is Backbone real MVC?
Let’s look at the description of the Model-View-Presenter pattern on Wikipedia:
an interface definingthe data to be displayed or otherwise acted upon in the user interface
passive interface that displays data (the model) and routes user commands (events) to the
presenter to act upon that data
acts upon the model and the view. It retrieves data from repositories (the model), and formats it
for display in the view
Model
View
Presenter
LAB
1. Organize the software architecture of the app using Backbone’s MVC paradigm
2. implement the Product, Producer, and User models
3. implement the Products and Producers collections
• if needed, override the sync method so that it can fetch data from the Loveitaly API
4. implement the views
5. implement the router of the app
References
http://backbonejs.org
Contact
Ivano Malavolta |
Gran Sasso Science Institute
iivanoo
ivano.malavolta@gssi.infn.it
www.ivanomalavolta.com

More Related Content

PDF
[2015/2016] JavaScript
PDF
[2015/2016] Require JS and Handlebars JS
PDF
HTML5: the new frontier of the web
PDF
Backbone.js
PDF
Handlebars & Require JS
PDF
HTML5 & CSS3 refresher for mobile apps
PDF
Modern development paradigms
PDF
Apache Cordova 4.x
[2015/2016] JavaScript
[2015/2016] Require JS and Handlebars JS
HTML5: the new frontier of the web
Backbone.js
Handlebars & Require JS
HTML5 & CSS3 refresher for mobile apps
Modern development paradigms
Apache Cordova 4.x

What's hot (20)

PDF
PDF
Angular or Backbone: Go Mobile!
PPTX
Angular jS Introduction by Google
 
PDF
[2015/2016] HTML5 and CSS3 Refresher
PDF
WebNet Conference 2012 - Designing complex applications using html5 and knock...
PDF
C# Advanced L09-HTML5+ASP
PDF
Web Components v1
PPT
MVC Demystified: Essence of Ruby on Rails
PPTX
HTL(Sightly) - All you need to know
PDF
PDF
Sightly - AEM6 UI Development using JS and JAVA
PPTX
Rapi::Blog talk - TPC 2017
PPTX
1. Spring intro IoC
 
PPTX
Codemotion 2013 - Designing complex applications using html5 and knockoutjs
PPTX
RapidApp - YAPC::NA 2014
PPTX
Aem best practices
PDF
Developing maintainable Cordova applications
PPT
Mvc architecture
PPTX
PDF
Angular - Chapter 6 - Firebase Integration
Angular or Backbone: Go Mobile!
Angular jS Introduction by Google
 
[2015/2016] HTML5 and CSS3 Refresher
WebNet Conference 2012 - Designing complex applications using html5 and knock...
C# Advanced L09-HTML5+ASP
Web Components v1
MVC Demystified: Essence of Ruby on Rails
HTL(Sightly) - All you need to know
Sightly - AEM6 UI Development using JS and JAVA
Rapi::Blog talk - TPC 2017
1. Spring intro IoC
 
Codemotion 2013 - Designing complex applications using html5 and knockoutjs
RapidApp - YAPC::NA 2014
Aem best practices
Developing maintainable Cordova applications
Mvc architecture
Angular - Chapter 6 - Firebase Integration
Ad

Viewers also liked (20)

PDF
[2015/2016] The REST architectural style
PDF
[2015/2016] Mobile thinking
PDF
[2015/2016] Apache Cordova APIs
PDF
[2015/2016] User-centred design
PDF
[2015/2016] Geolocation and mapping
PDF
[2015/2016] Apache Cordova
PDF
The road ahead for architectural languages [ACVI 2016]
PDF
[2015/2016] Local data storage for web-based mobile apps
PDF
[2015/2016] Modern development paradigms
PDF
[2015/2016] Introduction to software architecture
PDF
[2015/2016] AADL (Architecture Analysis and Design Language)
PDF
Web-based Hybrid Mobile Apps: State of the Practice and Research opportunitie...
PDF
Leveraging Web Analytics for Automatically Generating Mobile Navigation Model...
PDF
[2015/2016] User experience design of mobil apps
PDF
Design patterns for mobile apps
PDF
Mission planning of autonomous quadrotors
PDF
Beyond Native Apps: Web Technologies to the Rescue! [SPLASH 2016 - Mobile! k...
PDF
Modeling behaviour via UML state machines [Software Modeling] [Computer Scie...
PDF
SKA Systems Engineering: from PDR to Construction
PDF
[2015/2016] Software systems engineering PRINCIPLES
[2015/2016] The REST architectural style
[2015/2016] Mobile thinking
[2015/2016] Apache Cordova APIs
[2015/2016] User-centred design
[2015/2016] Geolocation and mapping
[2015/2016] Apache Cordova
The road ahead for architectural languages [ACVI 2016]
[2015/2016] Local data storage for web-based mobile apps
[2015/2016] Modern development paradigms
[2015/2016] Introduction to software architecture
[2015/2016] AADL (Architecture Analysis and Design Language)
Web-based Hybrid Mobile Apps: State of the Practice and Research opportunitie...
Leveraging Web Analytics for Automatically Generating Mobile Navigation Model...
[2015/2016] User experience design of mobil apps
Design patterns for mobile apps
Mission planning of autonomous quadrotors
Beyond Native Apps: Web Technologies to the Rescue! [SPLASH 2016 - Mobile! k...
Modeling behaviour via UML state machines [Software Modeling] [Computer Scie...
SKA Systems Engineering: from PDR to Construction
[2015/2016] Software systems engineering PRINCIPLES
Ad

Similar to [2015/2016] Backbone JS (20)

PDF
Backbone JS for mobile apps
PDF
Backbone.js
PPT
Backbone.js
PPTX
Backbone the Good Parts
PDF
Backbone
PPTX
Backbonejs for beginners
PDF
Viking academy backbone.js
PPTX
BACKBONE.JS & UNDERSCORE.JS
PDF
Backbone js
PDF
Intro to BackboneJS + Intermediate Javascript
PDF
Backbone.js
PDF
Understanding backbonejs
PDF
Backbonejs on Rails
PDF
Ember vs Backbone
PDF
Backbone Dev Talk by Max Mamis
PPTX
Creating Single Page Web App using Backbone JS
PPT
Backbone js
PPTX
BackboneJS Training - Giving Backbone to your applications
PPTX
Backbone.js
PDF
Backbone intro
Backbone JS for mobile apps
Backbone.js
Backbone.js
Backbone the Good Parts
Backbone
Backbonejs for beginners
Viking academy backbone.js
BACKBONE.JS & UNDERSCORE.JS
Backbone js
Intro to BackboneJS + Intermediate Javascript
Backbone.js
Understanding backbonejs
Backbonejs on Rails
Ember vs Backbone
Backbone Dev Talk by Max Mamis
Creating Single Page Web App using Backbone JS
Backbone js
BackboneJS Training - Giving Backbone to your applications
Backbone.js
Backbone intro

More from Ivano Malavolta (20)

PDF
On-Device or Remote? On the Energy Efficiency of Fetching LLM-Generated Conte...
PDF
Conducting Experiments on the Software Architecture of Robotic Systems (QRARS...
PDF
The H2020 experience
PDF
The Green Lab - Research cocktail @Vrije Universiteit Amsterdam (October 2020)
PDF
Software sustainability and Green IT
PDF
Navigation-aware and Personalized Prefetching of Network Requests in Android ...
PDF
How Maintainability Issues of Android Apps Evolve [ICSME 2018]
PDF
Collaborative Model-Driven Software Engineering: a Classification Framework a...
PDF
Experimenting on Mobile Apps Quality - a tale about Energy, Performance, and ...
PDF
Modeling objects interaction via UML sequence diagrams [Software Design] [Com...
PDF
Modeling behaviour via UML state machines [Software Design] [Computer Science...
PDF
Object-oriented design patterns in UML [Software Design] [Computer Science] [...
PDF
Structure modeling with UML [Software Design] [Computer Science] [Vrije Unive...
PDF
Requirements engineering with UML [Software Design] [Computer Science] [Vrije...
PDF
Modeling and abstraction, software development process [Software Design] [Com...
PDF
[2017/2018] Agile development
PDF
Reconstructing microservice-based architectures
PDF
[2017/2018] AADL - Architecture Analysis and Design Language
PDF
[2017/2018] Architectural languages
PDF
[2017/2018] Introduction to Software Architecture
On-Device or Remote? On the Energy Efficiency of Fetching LLM-Generated Conte...
Conducting Experiments on the Software Architecture of Robotic Systems (QRARS...
The H2020 experience
The Green Lab - Research cocktail @Vrije Universiteit Amsterdam (October 2020)
Software sustainability and Green IT
Navigation-aware and Personalized Prefetching of Network Requests in Android ...
How Maintainability Issues of Android Apps Evolve [ICSME 2018]
Collaborative Model-Driven Software Engineering: a Classification Framework a...
Experimenting on Mobile Apps Quality - a tale about Energy, Performance, and ...
Modeling objects interaction via UML sequence diagrams [Software Design] [Com...
Modeling behaviour via UML state machines [Software Design] [Computer Science...
Object-oriented design patterns in UML [Software Design] [Computer Science] [...
Structure modeling with UML [Software Design] [Computer Science] [Vrije Unive...
Requirements engineering with UML [Software Design] [Computer Science] [Vrije...
Modeling and abstraction, software development process [Software Design] [Com...
[2017/2018] Agile development
Reconstructing microservice-based architectures
[2017/2018] AADL - Architecture Analysis and Design Language
[2017/2018] Architectural languages
[2017/2018] Introduction to Software Architecture

Recently uploaded (20)

PDF
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
PPTX
Cloud computing and distributed systems.
PDF
Mobile App Security Testing_ A Comprehensive Guide.pdf
DOCX
The AUB Centre for AI in Media Proposal.docx
PPTX
MYSQL Presentation for SQL database connectivity
PDF
Reach Out and Touch Someone: Haptics and Empathic Computing
PDF
Advanced methodologies resolving dimensionality complications for autism neur...
PDF
Modernizing your data center with Dell and AMD
PPTX
Big Data Technologies - Introduction.pptx
PPTX
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
PDF
Approach and Philosophy of On baking technology
PDF
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
PDF
Per capita expenditure prediction using model stacking based on satellite ima...
PDF
Empathic Computing: Creating Shared Understanding
PDF
Agricultural_Statistics_at_a_Glance_2022_0.pdf
PDF
Network Security Unit 5.pdf for BCA BBA.
PDF
KodekX | Application Modernization Development
PDF
NewMind AI Monthly Chronicles - July 2025
PDF
Shreyas Phanse Resume: Experienced Backend Engineer | Java • Spring Boot • Ka...
PDF
Spectral efficient network and resource selection model in 5G networks
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
Cloud computing and distributed systems.
Mobile App Security Testing_ A Comprehensive Guide.pdf
The AUB Centre for AI in Media Proposal.docx
MYSQL Presentation for SQL database connectivity
Reach Out and Touch Someone: Haptics and Empathic Computing
Advanced methodologies resolving dimensionality complications for autism neur...
Modernizing your data center with Dell and AMD
Big Data Technologies - Introduction.pptx
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
Approach and Philosophy of On baking technology
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
Per capita expenditure prediction using model stacking based on satellite ima...
Empathic Computing: Creating Shared Understanding
Agricultural_Statistics_at_a_Glance_2022_0.pdf
Network Security Unit 5.pdf for BCA BBA.
KodekX | Application Modernization Development
NewMind AI Monthly Chronicles - July 2025
Shreyas Phanse Resume: Experienced Backend Engineer | Java • Spring Boot • Ka...
Spectral efficient network and resource selection model in 5G networks

[2015/2016] Backbone JS

  • 1. Gran Sasso Science Institute Ivano Malavolta Backbone JS
  • 2. Roadmap • Why Backbone • Events • Models • Collections • Views • Routers • Summary
  • 3. Why Backbone We are buildingapps, not web sites If your code is not structured: • it is extremely easy that your web app becomes a big mess of HTML + CSS + JavaScript • maintainingeach part of your app asks for a deep analysis of ALL its aspects (logic, presentation, etc.) • you may waste a whole day due to a missing <
  • 5. What we want to avoid Imagine yourself trying to change • how a movie should be rendered in your app • the REST API providing info about movies
  • 6. Why Backbone (1) From the Backbone website... manipulate the DOM lists of models represent data
  • 7. Why Backbone (2) Additionally,Backbone provides also features for: sync for managing how to persist models (default is via REST) events for managing how data and control are exchanged within your app router for managing the interaction flow among views
  • 8. Backbone in a nutshell
  • 9. Who is using Backbone?
  • 10. Roadmap • Why Backbone • Events • Models • Collections • Views • Routers • Summary
  • 11. Events Any object communicates with other objects via events It gives the object the ability to bind and trigger custom named events It is extremely useful for exchanging data and control among objects
  • 12. Events Basically, each object can: • listen to events • trigger events
  • 13. Events Two types of events: you define your own types of event built-in custom
  • 14. Events API object will react to the “alert” event (the “off” function detaches the event) event parameters the “alert” event is fired
  • 15. Events API Events methods: on object.on(event, callback, [context]) off object.off([event], [callback], [context]) once object.once(event, callback, [context]) trigger object.trigger(event, [*args]) listenTo object.listenTo(other, event, callback) stopListening object.stopListening([other], [event], [callback]) listenToOnce object.listenToOnce(other, event, callback)
  • 17. Roadmap • Why Backbone • Events • Models • Collections • Views • Routers • Summary
  • 18. Models Models represent your data Each model represents a data type in your app, together with the logic surroundingit, like: • persistence • conversions • validation • computed properties • access control MVC: Notify their observers about state using the Observer pattern
  • 19. Models You extend Backbone.Model with your domain-specific methods, and Model provides a basic set of functionalityfor managing changes, like: • getter and setter • id • constructor • REST-based persistence
  • 20. Example of model custom method setting an attribute event fired when “color” changes custom method invocation
  • 21. Model constructor and attributes initialize() it is triggered every time you create a new instance of a model it works also for collections and views it can take a JS object for setting also attributes get() & set() they are used to set and retrieve the value of certain attributes defaults a property named 'defaults' in your model declaration
  • 23. Model persistence Backbone.sync is the function that Backbone calls every time it attempts to read or save a model By default, it uses Ajax to make a REST-ish request to a server Resources represented as JSON strings
  • 24. Sync signature sync(method, model, [options]) method the CRUD method ("create“, "read“, "update", or "delete") model the model (or collection)to be synced options success and error callbacks, and all other jQuery request options example of overriden sync: http://bit.ly/KWdxNN Sync returns a jQuery XMLHttpRequest (jqXHR) object It implements the Promise interface
  • 25. Sync usage Normally you will not use the sync method directly, you will do it implicitlywhen you call one of these methods Model • fetch: gets the most up-to-date values of the model instance • save: persists the model instance • destroy: deletes the model instance Collection • fetch: gets all the models of the collection from the server • create: creates a model, saves it to the server and adds it to the collection
  • 26. Overriding sync You can override it in order to use a different persistence strategy, such as: • WebSockets • Local Storage • WebSQL Backbone.sync is the default global function that all models use unless the models have a sync method specifically set
  • 28. Roadmap • Why Backbone • Events • Models • Collections • Views • Routers • Summary
  • 29. Collections Collections are ordered sets of models You can: • bind change events to be notified when any model in the collection has been modified • listen for add and remove events • fetch the collection from the server (or other persistence layers) • find models or filter collections themeselves The model attribute of a collection represents the kind of model that can be stored in it Any event that is triggered on a model in a collection will also be triggered on the collection directly MVC: Notify their observers about state using the Observer pattern (same as models)
  • 32. Roadmap • Why Backbone • Events • Models • Collections • Views • Routers • Summary
  • 33. Views Views represent and manage the visible parts of your application They are also used to • listen to user interaction events • and react accordingly views can be rendered at any time, and inserted into the DOM you get high-performance UI rendering with as few reflows and repaints as possible MVC: a view observes a model, and updates itself according to the state of the model + manage user inputs (it’s a controller, to this sense)
  • 34. Interaction with the DOM All views refer to a DOM element at all times this.el is a reference to the DOM element, it is created from: tagName for example body, ul, span, img className class name of some element within the DOM id id of an element within the DOM If none of them is specified, this.el is an empty <div>
  • 35. Rendering the view The render() method is used to update the this.el element with the new HTML The default implementation of render() is a no-op à you have to override it to update this.el with your HTML code Backbone is agnostic with respect to your code in render(), however... you are STRONGLY encouraged to use a JavaScript templating library here
  • 37. Interaction with the user Events map “event_name selector”: callback Events callbacks
  • 39. Roadmap • Why Backbone • Events • Models • Collections • Views • Routers • Summary
  • 40. The router Backbone.Router provides methods for routingclient-side pages, and connecting them to actions and events At a minimum, a router is composed of two main parts: routes an hash that pairs routes to actions actions JS functionstriggered when certain routes are navigated It can be seen as the “implementation” of a navigation model
  • 41. Routing Every router contains an hash that maps routes to functions on your router URLs fragments can also contain dynamic data via Backbone-specific URL parts: parameter (:param) match a single URL component between slashes splat (*fragment) match any number of URL components
  • 43. History History serves as a global router to 1. handle hashchange events 2. match the appropriate route 3. trigger callbacks You should never access it directly, you just need call Backbone.history.start() to begin monitoringhashchange events, and dispatching routes in your app Call Backbone.history.navigate(ROUTE_NAME, {trigger: true}); to activate a specific route of the router Technically, it uses the HTML5 History API to listen to its job For older browsers, it uses URL hash fragments as fallback
  • 45. Roadmap • Why Backbone • Events • Models • Collections • Views • Routers • Summary
  • 46. Classical workflow 1. You dig into JSON objects 2. Look up elements in the DOM 3. Update the HTML by hand
  • 47. Backbone-based workflow • You organize your interface into logical views backed by models • Each view can be updated independently when the model changes, without having to redraw the page You can bind your view‘s render() function to the model‘s "change” event à now everywhere that model data is displayed in the UI, it is always immediately up to date
  • 48. Is Backbone real MVC? Let’s look at the description of the Model-View-Presenter pattern on Wikipedia: an interface definingthe data to be displayed or otherwise acted upon in the user interface passive interface that displays data (the model) and routes user commands (events) to the presenter to act upon that data acts upon the model and the view. It retrieves data from repositories (the model), and formats it for display in the view Model View Presenter
  • 49. LAB 1. Organize the software architecture of the app using Backbone’s MVC paradigm 2. implement the Product, Producer, and User models 3. implement the Products and Producers collections • if needed, override the sync method so that it can fetch data from the Loveitaly API 4. implement the views 5. implement the router of the app
  • 51. Contact Ivano Malavolta | Gran Sasso Science Institute iivanoo ivano.malavolta@gssi.infn.it www.ivanomalavolta.com