Skip to Content
Developing Backbone.js Applications
book

Developing Backbone.js Applications

by Addy Osmani
May 2013
Intermediate to advanced
374 pages
8h 53m
English
O'Reilly Media, Inc.
Content preview from Developing Backbone.js Applications

Chapter 4. Exercise 1: Todos—Your First Backbone.js App

Now that we’ve covered fundamentals, let’s write our first Backbone.js application. We’ll build the Backbone Todo List application exhibited on TodoMVC.com. Building a todo list is a great way to learn Backbone’s conventions (see Figure 4-1). It’s a relatively simple application, yet technical challenges surrounding binding, persisting model data, routing, and template rendering provide opportunities to illustrate some core Backbone features.

Let’s consider the application’s architecture at a high level. We’ll need:

  • A Todo model to describe individual todo items

  • A TodoList collection to store and persist todos

  • A way of creating todos

  • A way to display a listing of todos

  • A way to edit existing todos

  • A way to mark a todo as completed

  • A way to delete todos

  • A way to filter the items that have been completed or are remaining

Figure 4-1. A todo list—the first Backbone.js application we will be writing

Essentially, these features are classic CRUD (create, read, update, delete) methods. Let’s get started!

Static HTML

We’ll place all of our HTML in a single file named index.html.

Header and Scripts

First, we’ll set up the header and the basic application dependencies: jQuery, Underscore, Backbone.js, and the Backbone localStorage adapter.

<!doctype html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" ...
Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.

Read now

Unlock full access

More than 5,000 organizations count on O’Reilly

AirBnbBlueOriginElectronic ArtsHomeDepotNasdaqRakutenTata Consultancy Services

QuotationMarkO’Reilly covers everything we've got, with content to help us build a world-class technology community, upgrade the capabilities and competencies of our teams, and improve overall team performance as well as their engagement.
Julian F.
Head of Cybersecurity
QuotationMarkI wanted to learn C and C++, but it didn't click for me until I picked up an O'Reilly book. When I went on the O’Reilly platform, I was astonished to find all the books there, plus live events and sandboxes so you could play around with the technology.
Addison B.
Field Engineer
QuotationMarkI’ve been on the O’Reilly platform for more than eight years. I use a couple of learning platforms, but I'm on O'Reilly more than anybody else. When you're there, you start learning. I'm never disappointed.
Amir M.
Data Platform Tech Lead
QuotationMarkI'm always learning. So when I got on to O'Reilly, I was like a kid in a candy store. There are playlists. There are answers. There's on-demand training. It's worth its weight in gold, in terms of what it allows me to do.
Mark W.
Embedded Software Engineer

You might also like

Beginning Backbone.js

Beginning Backbone.js

James Sugrue
Backbone.js Testing

Backbone.js Testing

Ryan Glenn Roemer

Publisher Resources

ISBN: 9781449328535Errata Page