gpt4 book ai didi

javascript - 在同一条路线上管理 Ember 多个 RSVP Promises

转载 作者:行者123 更新时间:2023-11-29 16:09:02 26 4
gpt4 key购买 nike

我正在使用 GitHub API 以在特定路径中加载模型

我正在做两个 promise ,一个是关于我的个人 github 详细信息:https://api.github.com/users/user另一个用于我的 GitHub 存储库 https://api.github.com/users/user/repos

我可以分别加载模型,但问题是我不知道如何在我的特定路径中同时加载两个模型。

查看代码

var IndexRoute = Ember.Route.extend({
model: function(params) {
var url, self, git;
self = this;
git = this.store.createRecord('git',{});
url = 'https://api.github.com/users/user';
return new Ember.RSVP.Promise(function(resolve, reject) {
return Ember.$.getJSON(url, function(data) {
var item = [];
git.setProperties({
name: data.name,
login: data.login,
location: data.location,
company: data.company,
followers: data.followers,
following: data.following
});
item.pushObject(git);
return resolve(item);
});
});
},
model: function(params){
var self, url, repoListProxy;
self = this;
url = 'https://api.github.com/users/user/repos';
repoListProxy = Ember.ArrayProxy.create({
content: []
});
return new Ember.RSVP.Promise(function(resolve, reject) {
return Ember.$.getJSON(url, function(repos) {
if (repos.length) {
repos.toArray().forEach(function(item, index, arr){
var repo;
repo = self.createReposList(item, repoListProxy);
});
repos = repoListProxy.get('content');
return resolve(repos);
}
});
});
},
createReposList: function(repo, arr){
var record
record = this.store.createRecord('repo',{}),
record.setProperties({
name: repo.name,
description: repo.description
})
arr.pushObject(record);
return record;
},
});

如何在我的特定路由中使用 Ember.RSVP.Promise 加载这些多个模型?

最佳答案

由于您发布的代码太长而无法阅读,我没有根据它实现解决方案。这是在模型 Hook 的单个路由中加载多个 promise 的常见示例。

   model: function() {
var store = self.get('store');
var someRecord = store.createRecord('foo/bar', {});
var somePromise = imported_promise(someRecord);

return Ember.RSVP.hash({
accessRights: somePromise,
itemData: somePromise.then(function(resolved) {
// Do something here, promise is resolved.
})
myRecord: someRecord,
});
},

现在,如果您需要从模板或 Controller 中的路由访问任何内容。

您将首先引用模型,然后引用属性。

{{model.myRecord}}this.get('model.myRecord')

因为你对我投了反对票,所以我决定为你写这篇文章。

我推荐使用 Ic-AJAX:https://github.com/rwjblue/ember-cli-ic-ajax无法使用 store.find 时的异步调用

model: function() {
var store = this.get('store');


var userUrl = 'https://api.github.com/users/user';
var reposUrl = 'https://api.github.com/users/user/repos';

var usersPromise = function() {
return ic.ajax.request(userUrl).then(function(data) {
return store.createRecord('git', {
name: data.name,
login: data.login,
location: data.location,
company: data.company,
followers: data.followers,
following: data.following
})
};
};

var repositoriesPromise = function() {
return ic.ajax.request(reposUrl).then(function(repos) {
return repos.map(function(repo) { // map returns new array no need to write container = [] . container.push(bla)
return store.createRecord('repos', {
name: repo.name,
description: repo.description
});
})
};
}

return Ember.RSVP.hash({
users: usersPromise,
repositories: repositoriesPromise
});

},

由于您仍在使用不同的方法,我继续搜索其语法

   var gituserPromise = function() {
return Ember.$.ajax(userUrl, {

success: function(data) {
return store.createRecord('git', {
name: data.name,
login: data.login,
location: data.location,
company: data.company,
followers: data.followers,
following: data.following
})
},
error: function(reason) {
reject(reason);
}});
};

return Ember.RSVP.hash({
gitUser: gituserPromise()
});

在 hbs 我现在可以做 {{model.gitUser.name}}

新链接http://emberjs.jsbin.com/rutezi/2/edit?html,js,output

关于javascript - 在同一条路线上管理 Ember 多个 RSVP Promises,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33717667/

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