使用Angular时,我通常使用JQuery的$.Deferred
对象来即时创建承诺。除了实际的HTTP请求之外,它非常适合在promise中返回任意模拟数据:
getMockData: function() {
var deferred = $.Deferred();
deferred.resolve({mockData: 'foo-bar'});
return deferred.promise();
}
非常简单。也就是说,我现在使用的是Aurelia,它与Angular的JQuery(或jqLite)并没有关联。因此,我失去了$.Deferred()
。是否有类似的库可以提供与$.Deferred()
相同的功能?
否则,安装JQuery并在必要时使用$.Deferred()
被认为是不恰当或不好的做法?我怀疑它只是暂时的,但也许不是。我并不反对JQuery,但显然不想导入它只是为了获得一个模块。
Aurelia示例:
import {DataService} from './data-service';
import {inject} from 'aurelia-framework';
@inject(DataService)
export class PatientService {
constructor(dataService) {
this.dataService = dataService;
}
getPatients(url, emr) {
// Server incomplete, so comment out the real call (for now)
// return this.dataService.get(url + '/patients?emr=' + emr);
[generate and return a promise here. Cool to just use $.Deferred()?]
}
}
答案 0 :(得分:5)
getPatients(url, emr) {
// Server incomplete, so comment out the real call (for now)
// return this.dataService.get(url + '/patients?emr=' + emr);
return new Promise((resolve) => resolve({mockData: 'foo-bar'}));
// or
// return Promise.resolve({mockData: 'foo-bar'});
}
一旦适当的承诺实现已经存在,那个人不应该回到jQuery范围之外的Deferred(反)模式。
dataService
可以在内部进行模拟,如果它是不断需要的话。