我应该如何使用Backbone.Marionette和requireJs引导我的Web应用程序

Lor*_*ard 8 requirejs backbone.js backbone-routing marionette

让我们说我的应用程序有效,但我喜欢学习并找到最好的做事方式.
我非常感谢这篇关于将骨干路由器减少到无配置的帖子.
以下bbclonemail不使用需要.

实际上我的实现是一个整体块(app.js,router.js).

这是我的问题:
1)router module router.js回报应该是什么?
2)我应该如何删除The Callback Functionsrouter.js
3)app module app.js回报应该是什么?
4)我应该如何解耦app.js许多其他应用程序(例如:主要,任务,项目)


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;

});
Run Code Online (Sandbox Code Playgroud)

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
    };

});
Run Code Online (Sandbox Code Playgroud)

ant*_*njs 1

对于路由器部分,您应该像这样制作:

路由器.js

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

        routes: {
            tasks: 'tasks',
            projects: 'projects',
            // many others  keys/values
            '*defaults': 'home'
        }
    });
    return new AppRouter({constroller: rooterController})
});
Run Code Online (Sandbox Code Playgroud)