我正在使用GitHub API来加载特定路径中的模型
我正在为我的个人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加载这些多个模型?
答案 0 :(得分:6)
由于您发布的代码太长而无法阅读,因此我没有实施基于它的解决方案。这是在模型钩子中的单个路径中加载多个承诺的常见示例。
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,
});
},
现在,如果您需要从模板或控制器中的路径访问任何内容。
首先引用模型然后引用属性。
{{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