Как мне загрузить свое веб-приложение с помощью Backbone.Marionette и requireJs

Допустим, мое приложение работает, но я люблю учиться и находить лучший способ делать вещи.
Я очень ценю этот пост о Сведении магистральных маршрутизаторов к не более чем конфигурации.
И следующий bbclonemail, который не использует, требует.

На самом деле моя реализация представляет собой монолитный блок (app.js, router.js).

Вот мои вопросы:
1) Что должен возвращать модуль маршрутизатораrouter.js?
2) Как мне удалить функции обратного вызова из router.js ?
3) Что должен возвращать модуль приложения app.js?
4) Как мне отделить app.jsот многих других приложений (например: main, tasks, Projects)


app.js

// app.js
define([
'router'
// some modules
],
function (router, Backbone, HeaderView)
{
    "use strict";
    var myApp = new Backbone.Marionette.Application();

    myApp.addRegions({
        header: '#header',
        sidebar: '#sidebar',
        mainColumn: '#main-column',
        rightColumn: '#right-column'
    });

    myApp.initHeader = function () {
        var headerView = new HeaderView();
        myApp.header.show(headerView);
    }

    // many others many views

    myApp.start();

    myApp.initialize = function() {
        router.initialize();
        Backbone.history.start();
    }

    return myApp;

});

router.js

// router.js
define([
// some modules
],
function (Backbone)
{
    "use strict";
    var AppRouter = Backbone.Marionette.AppRouter.extend({

        routes: {
            tasks: 'tasks',
            projects: 'projects',
            // many others  keys/values
            '*defaults': 'home'
        },

        getApp: function ()
        {
            var mainApp;
            require(['js/app'], function (app) {
                mainApp = app;
            });
            return mainApp;
        },

        home: function()
        {
            var app = this.getApp();
            app.initHeader();
            app.initSidebar();
            app.initTaskDetails();
        },

       // many others callbacks

    });

    var initialize = function() {
        new AppRouter;
    };
    return {
        initialize: initialize
    };

});

8
задан Lorraine Bernard 15 June 2012 в 10:19
поделиться