/Backbonejs-Router-Title-Helper

Overrides Backbone.js router to provide title updates based on the current route.

Primary LanguageJavaScript

Backbone.js Router Title Helper Build Status

When developing single page applications the page title is often over looked and the usability of your application suffers. This script aims to make it easier to update the page title of your application by providing a single place for maintaining your applications page titles. This script overrides the Backbone.js Router to provide page title updates based on the current route. Note: if you have another plugin that touches the Backbone.Router you may run into issues.

Use

This script is tested against Backbone.js 1.0.0. Include the script in your page after Backbone.js has loaded.

<script src="backbone.js" type="text/javascript"></script>
<script src="backbone.router.title.helper.js" type="text/javascript"></script>

and then in your router provide a titles object literal whose keys map to route function names and whose values are page titles. Be sure to provide a default for routes to fall back to in case you forget to include a title. An error is thrown if you fail to specify a routes title and a default title is not found. Example router:

var Router = Backbone.Router.extend({
    routes: {
        'a': 'aRoute',
        'b': 'bRoute'
    },

    titles: {
        'aRoute': 'aTitle',
        // this is the default title that routes will fall back to
        'default': 'defaultRoute'
    },

    aRoute: function() {
        // This will trigger the page title aRoute
    },

    bRoute: function() {   
        // This will trigger the page title defaultRoute since there is no bRoute specified
    }
});

You can also specify a function or a router method name as the return value for a title. This is useful when you need to compute a value for a title. For example:

var Router = Backbone.Router.extend({
    ...

    titles: {
        "cRoute": function() {
            return "cTitle — " + this.titles.default;
        },
        "dRoute": "dRouteTitle",
        "default": "Sample Application"
    },

    dRouteTitle: function() {
        return "dTitle — " + this.titles.default;
    }

    ...
});

Promised title

Sometimes, to set a page title, you need to fetch the model data from the server first. This helper has support for promised values. Example usage with jQuery.Deferred:

var Router = Backbone.Router.extend({
    ...

    routes: {
        "show/:id": "show"
    },

    titles: {
        "show": new jQuery.Deferred()
    },

    show: function (id) {
        var model = new App.Model({id: id});
        this.listenTo(model, "sync", function (model) {
            this.titles['show'].resolve(model.get('title'));
        });
        model.fetch();
    }

    ...
});

Contribution

Feel free to contiribute!

First run npm install in the project directory to fetch dependencies. Then simply run grunt to run linter, tests and to build minified version.