Book Image

Backbone.js Blueprints

By : Andrew Burgess
Book Image

Backbone.js Blueprints

By: Andrew Burgess

Overview of this book

<p>Backbone.js is an open source, JavaScript library that helps you to build sophisticated and structured web apps. It's important to have well-organized frontend code for easy maintenance and extendability. With the Backbone framework, you'll be able to build applications that are a breeze to manage.<br /><br />In this book, you will discover how to build seven complete web applications from scratch. You'll learn how to use all the components of the Backbone framework individually, and how to use them together to create fully featured applications. In addition, you'll also learn how Backbone thinks so you can leverage it to write the most efficient frontend JavaScript code.<br /><br />Through this book, you will learn to write good server-side JavaScript to support your frontend applications. This easy-to-follow guide is packed with projects, code, and solid explanations that will give you the confidence to write your own web applications from scratch.</p>
Table of Contents (14 chapters)
Backbone.js Blueprints
Credits
About the Author
About the Reviewers
www.PacktPub.com
Preface
Index

Joining a room


Once a user has selected their screen name, the next step is selecting a room. This is a bit more complex than choosing a name because they can either choose from a list of existing rooms, or they can start a new room by typing in a new name. If the user types in the name of an existing room, they'll go to the existing rooms because we obviously can't have multiple rooms with the same name. The tricky part in all this is that while we're calling them rooms, they're actually more like tags. The only place they exist is as a property on the chat messages; they aren't stored on their own. When a user creates a new room, there's no actual record of the room until they write the first message in that room. If they create a room and then close the page, the room doesn't exist. All this will make it a bit trickier to keep track of the rooms, but we love a good challenge, right?

Open a new file, rooms.js, in public. Just like our user.js file, this will have a model, collection, model...