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

时间:2012-06-15 10:19:52

标签: backbone.js requirejs marionette backbone-routing

让我们说我的应用程序有效,但我喜欢学习并找到最好的做事方式 我非常感谢这篇关于Reducing Backbone Routers To Nothing More Than Configuration的帖子 以及未使用的bbclonemail需要。

实际上我的实施是一个单一的块( app.js router.js )。

这是我的问题:
1)router module router.js应该返回什么? 2)如何从The Callback Functions删除router.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;

});

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

});

1 个答案:

答案 0 :(得分:1)

对于路由器部分,你应该这样:

<强> router.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})
});