我在與在我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;
}
);
現在什麼是解決這個問題的最好方法是什麼?我是全新的,所以我不知道最佳做法是什麼..
也是正確的,我添加在我的控制器的意見?或者我應該在其他地方做那個?
在此先感謝
你可以請把你的應用程序文件? –
是的,我已經添加了它,請看看:) –