如何使用angular2和typescript链接3个Promises

Ant*_*ère 7 javascript promise signalr typescript angular

我已经成功地锁定了承诺,但我发现我的方式足够复杂:我想知道是否有更优雅的方式来做到这一点.

我使用Angular2,Typescript和signalR.

我有一个服务getIntervention,通过Id从服务器返回一个对象.

在调用之前getIntervention,我想检查客户端是否连接到服务器,在连接到服务器之前,我希望加载SignalR脚本.

所以我创建了第一个scriptLoadedPromise等待SignalR脚本加载的承诺.当scriptLoadedPromise解决了一个新的承诺connectionPromise将创建一个等待要建立连接.

何时connectionPromise 解决,请致电该服务getIntervention.

对于每一个承诺,我添加了一个名为回调scriptLoadedconnectionDetected 该呼叫resolve().

这是我的代码:

public loadIntervention( numFI : number ) : Promise<Intervention>
{

    let scriptLoadedPromise : Promise<Intervention> = new Promise( ( resolve, reject ) =>
    { 
        // si le script est chargé alors la promesse est déjà tenue
        if ( this.isScriptLoaded )
            resolve();
        else
            this.scriptLoaded = ( () => { resolve(); } ) ;
    }).then
    ( () => {
        let connectionPromise : Promise<Intervention> = new Promise( (resolve, reject) =>
        {
            // si le serveur est connecté alors la promesse de connection est déjà tenue
            if ( this.Connected )
                resolve();
            else
                this.connectionDetected = ( () => { console.log("RECONNETED !!!!!"); resolve(); } );

        } )
        .then( ()  => { return this.proxy.server.getIntervention( numFI ); } );

        return connectionPromise;
    });


    return scriptLoadedPromise;
}
Run Code Online (Sandbox Code Playgroud)

有没有办法简化3个承诺链接的实现?

Oli*_*der 7

如果这些承诺相互依赖,那么它与您已经创建的相似.您可以通过将逻辑放入单独的方法(如例如)来增强代码风格

private firstAction():Promise<any> {
  return new Promise<any>(
    (resolve, reject) => { ... }
  );
}
private secondAction():Promise<any> {
  return new Promise<any>(
    (resolve, reject) => { ... }
  );
}
execute() {
  this.firstAction().then(
    (firstResult:any) => this.secondAction().then(
      (secondResult:any) => { ... }
    );
  )
}
Run Code Online (Sandbox Code Playgroud)

如果允许并行执行承诺,您可以使用Promise.all(),例如

execute() {
  let promises:Promise<any>[] = [];
  promises.push(this.firstAction());
  promises.push(this.secondAction());

  Promise.all(promises).then(
    () => { ... }
  );
}
Run Code Online (Sandbox Code Playgroud)