gpt4 book ai didi

requirejs - 使用 RequireJS 的主干关系子模型

转载 作者:行者123 更新时间:2023-12-05 01:18:06 26 4
gpt4 key购买 nike

我正在尝试找到一种将 Backbone-relational 子模型与 RequireJS 一起使用的方法,其中子模型与 super 模型位于不同的文件中。

例如:

// app.js
define(function() {
var app = {};
var app.ns = {};
Backbone.Relational.store.addModelScope(app.ns);
});

// Classroom/Person.js
define(["app", "./Student", "./Professor"], function(app) {
app.ns.Classroom.Person = Backbone.RelationalModel.extend({
subModelTypes: {
'Student': 'Classroom.Student'
'Professor': 'Classroom.Professor'
},

alertHello: function() {}
});

return app.ns.Classroom.Person;
});

// Classroom/Student.js
define(["require", "app", "./Person"], function(require, app) {
app.ns.Classroom.Student = require("./Person").extend({
alertHello: function() {
alert("Hello, I am student " + this.get("name"));
}
});

return app.ns.Classroom.Student;
});

// Classroom/PersonCollection.js
define(["app", "./Person"], function (app, Person) {
app.ns.Classroom.PersonCollection = Backbone.Collection.extend({
model: Person
});
});

// alertPeople.js
define(["Classroom/PersonCollection"], function(PersonCollection) {
var people = PersonCollection([{"name": "Bob", "type": "Person"}]);
people.each(function(person) {
person.alertHello();
});
});

当我执行 alertPeople.js 时,我希望收到“你好,我是 Bob 学生”的警报,但我收到了这个错误: Uncaught Error: Module name "Classroom/Person" has not been loaded yet for context: _由于我的循环依赖。解决这个问题的可能解决方案是什么?

我的下一个问题可能与 Backbone-relational 的范围有关。在我的 app.js 文件中,我添加了范围的 app.ns 部分,并确保我的所有模型都在 app.ns 对象中定义。我这样做是为了当我定义我的 subModelTypes 时,它实际上可以引用子模型,但我不确定这是否可行,因为我无法解决循环依赖问题。

任何帮助是极大的赞赏。谢谢!

最佳答案

我最终解决了这个问题,我希望这可以帮助其他人。

首先,我将代码修改为以下内容:

// app.js
define(function() {
var app = {};
var app.ns = {};
Backbone.Relational.store.addModelScope(app.ns);
});

// Classroom/Person.js
define(["app"], function(app) {
app.ns.Classroom.Person = Backbone.RelationalModel.extend({
subModelTypes: {
'Student': 'Classroom.Student'
'Professor': 'Classroom.Professor'
},

alertHello: function() {}
});

return app.ns.Classroom.Person;
});

// Classroom/Student.js
define(["app", "./Person"], function(app, Person) {
app.ns.Classroom.Student = Person.extend({
alertHello: function() {
alert("Hello, I am student " + this.get("name"));
}
});

return app.ns.Classroom.Student;
});

// Classroom/PersonCollection.js
define(["app", "./Person", "./Student", "./Professor"], function (app, Person) {
app.ns.Classroom.PersonCollection = Backbone.Collection.extend({
model: Person
});
});

// alertPeople.js
define(["Classroom/PersonCollection"], function(PersonCollection) {
var people = PersonCollection([{"name": "Bob", "type": "Person"}]);
people.each(function(person) {
person.alertHello();
});
});

我的更改包括删除 Classroom/Person.js 文件中的 Student 和 Professor 依赖项,并将它们移动到 Classroom/PersonCollection.js 文件中。

在此之后,我遇到了一个 Backbone-relational 的错误,其中 addModelScope 有一个关于子模型和命名空间的错误,但我修复了它并提出了一个拉取请求: https://github.com/PaulUithol/Backbone-relational/pull/211 ,已被接受。

可以在 https://github.com/andrewferk/backbone-relational-submodels 找到更完整的示例。 .

关于requirejs - 使用 RequireJS 的主干关系子模型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13276388/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com