我在与在我marionette.js应用循环引用一个问题..循环引用marionette.js
的问题是:
App.js创建了一个具有控制器的路由器,并且控制器需要再次app.js所以它可以将视图添加到区域..正如你可以看到下面(控制器)当我打印Application
它返回undefined,因为circulare参考..
controller.js:
define(
['app', 'views/ProjectItemView'],
function (Application, ProjectItemView)
{
'use strict';
console.log(Application); // undefined
return Marionette.Controller.extend({
showProjects : function()
{
Application.main.show(new ProjectItemView());
console.log('project');
}
});
}
);
router.js:
define
(
['marionette'],
function(Marionette)
{
'use strict';
return Marionette.AppRouter.extend
(
{
appRoutes:
{
'dashboard/projects' : 'showProjects'
}
}
);
}
);
app.js
define
(
[
'backbone', 'marionette', 'jquery', 'routers/DashboardRouter', 'controllers/DashboardController',
'views/dashboard/Header'
],
function(Backbone, Marionette, $, DashboardRouter, DashboardController, Header)
{
'use strict';
var app = new Marionette.Application();
app.addRegions({
header: '#header',
main: '#main',
});
app.header.show(new Header());
app.on('initialize:after', function() {
Backbone.history.start({pushState: true});
app.router = new DashboardRouter({
controller : DashboardController
});
});
$(document).on("click", "a[href^='/']", function(event)
{
var href = $(event.currentTarget).attr('href');
console.log(href);
event.preventDefault();
app.router.navigate(href, {trigger: true});
return false;
});
return app;
}
);
现在什么是解决这个问题的最好方法是什么?我是全新的,所以我不知道最佳做法是什么..
也是正确的,我添加在我的控制器的意见?或者我应该在其他地方做那个?
在此先感谢
你可以请把你的应用程序文件? –
是的,我已经添加了它,请看看:) –