サイト全体の複数のビューでアクセスする必要があるユーザー モデルがあります。マリオネット アプリケーションでグローバル モデルを作成できますか?
だから私はそれを介してアクセスできます:
window.MarionetteApp.userModel
これは、私がこれまでに持っていた唯一の理にかなっている考えです。誰かが backbone.marionette でユーザーを構成するより良い方法を持っていない限り、私はアイデアを受け入れます。
サイト全体の複数のビューでアクセスする必要があるユーザー モデルがあります。マリオネット アプリケーションでグローバル モデルを作成できますか?
だから私はそれを介してアクセスできます:
window.MarionetteApp.userModel
これは、私がこれまでに持っていた唯一の理にかなっている考えです。誰かが backbone.marionette でユーザーを構成するより良い方法を持っていない限り、私はアイデアを受け入れます。
Marionette.RequestReponseを使用することをお勧めします。それを使用すると、次のようなことができます。
MarionetteApp.reqres.setHandler('currentUser', function() {
if(MarionetteApp.currentUser) return MarionetteApp.currentUser;
var user = MarionetteApp.currentUser = new MarionetteApp.models.User(/* whatever */);
return user;
});
そして、次のようにモデルを取得します。
var user = MarionetteApp.request('currentUser');
良い例として、David Sulc は次のように書いています。
ContactManager.module("Entities", function(Entities, ContactManager, Backbone, Marionette, $, _){
Entities.Header = Backbone.Model.extend({
initialize: function(){
var selectable = new Backbone.Picky.Selectable(this);
_.extend(this, selectable);
}
});
Entities.HeaderCollection = Backbone.Collection.extend({
model: Entities.Header,
initialize: function(){
var singleSelect = new Backbone.Picky.SingleSelect(this);
_.extend(this, singleSelect);
}
});
var initializeHeaders = function(){
Entities.headers = new Entities.HeaderCollection([
{ name: "Contacts", url: "contacts", navigationTrigger: "contacts:list" },
{ name: "About", url: "about", navigationTrigger: "about:show" }
]);
};
var API = {
getHeaders: function(){
if(Entities.headers === undefined){
initializeHeaders();
}
return Entities.headers;
}
};
ContactManager.reqres.setHandler("header:entities", function(){
return API.getHeaders();
});
});
私はこれをやってしまった
MyApp.addInitializer(function(){
this.currentUser = new UserModel();
});