我的工作客户端破解:
我覆盖了适配器上的 ajaxOptions 以便可以使用store.find('model', { loadNext: '/loadMoarLink' }) 直接访问 URL:
ajaxOptions(url, type, options) {
if(options && options.data && options.data.loadNext) {
url = options.data.loadNext;
delete options.data.loadNext
}
return this._super(url, type, options);
}
要访问链接,我会覆盖适配器上的 normalizeResponse 以将链接写入元对象:
normalizeResponse: function(store, primaryModelClass, payload, id, requestType) {
let links = payload.links;
let response = this._super(...arguments);
if(!get(response, 'meta')) {
set(response, 'meta', Ember.Object.create());
}
set(response, 'meta.links', links);
return response;
}
然后我可以从setupController 访问元数据:
controller.set('meta', Ember.copy(this.store.metadataFor('model'), true));
并且始终查询next 数据:
this.store.query('model', {
loadNext: this.get('controller.meta.links.next')
})