临时承诺库

时间:2015-12-16 21:39:58

标签: javascript es6-promise

使用Angular时,我通常使用JQuery的$.Deferred对象来即时创建承诺。除了实际的HTTP请求之外,它非常适合在promise中返回任意模拟数据:

getMockData: function() {
   var deferred = $.Deferred();
   deferred.resolve({mockData: 'foo-bar'});
   return deferred.promise();
}

非常简单。也就是说,我现在使用的是Aurelia,它与Angular的JQuery(或jqLit​​e)并没有关联。因此,我失去了$.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()?]

  }

}

1 个答案:

答案 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可以在内部进行模拟,如果它是不断需要的话。