依存関係の一部がrequire JSを介してロードされたバックボーンモデルがあります。Require.js の循環依存の問題を回避するために、この方法で処理しています。(モデル、コレクション、およびビューを必要とする複数のファイルがあり、それらのいくつかは循環しています。)
問題は、モデルに設定された属性 ( this
) がundefined
、require ステートメントの外に出てくることです。コードはここにあります:
define(["jquery", "backbone"],
function($, Backbone) {
var Model = Backbone.Model.extend({
initialize: function(options) {
var that = this;
require(["collections/agenciesCollection", "collections/usersCollection", "models/userModel"], function(Agencies, Users, User) {
that.agencies = (!options || !options.agencies) ? new Agencies() : new Agencies(options.agencies);
that.users = (!options || options.users) ? new Users() : new Users(options.users);
if(!options || !options.contact) that.set("contact", new User()); else that.set("contact", new User(options.contact));
if(!options || !options.admin) that.set("admin", new User()); else that.set("admin", new User(options.contact));
console.log(that.agencies); // This is set to a collection
});
console.log(this.agencies); // This is 'undefined'
console.log(this); // This has an attribute "agencies" listed in Chrome inspector
}
return Model;
});