.NET 開発基盤部会 Wiki」は、「Open棟梁Project」,「OSSコンソーシアム .NET開発基盤部会」によって運営されています。

目次

概要

詳細

コールバック地獄の解決

コールバックのネストが深くなりコードが読み難くなるということがある。

Promiseの簡潔な仕組みの解説

Promiseオブジェクト

組み込みクラス。

非同期処理の「実装」方法

以下のようにPromiseオブジェクトを利用して非同期処理を実装する。

非同期処理の「実行」方法

比較

従来型

従来型では、非同期処理を順次実行する場合、
非同期処理に非同期処理(コールバック)を渡すため、
以下の様に非同期処理がネストすることになる。

fetchSomething1(function() {
  fetchSomething2(function() {
    fetchSomething3(function() {
      fetchSomething4(doSomethingFinally);
    });
  });
});

※ resolveをrejectに書き換えると動作を変更させることができる。

Promise型

メリット

メソッド・チェーンで非同期処理を順次実行できる。

※ 各非同期処理(fetchSomething、doSomething)は、
 Promiseオブジェクトを返すように実装されている。

※ 各非同期処理に「値を渡したり」・「処理を追加したり」する場合は以下のようにする。

.then(
  function(rtn) {
    alert(rtn);
    return fetchSomething2(rtn);
}).then(...

サンプル・コード

ダミー非同期関数を使用したサンプル・コード

// 非同期処理関数はPromiseオブジェクトを返すように実装する。
var fetchSomething1 = function() {

  // Promiseオブジェクトは、非同期処理関数の中で以下のように生成される。
  return new Promise(

    // Promiseオブジェクトのコンストラクタに非同期処理の
    // 「本体となる非同期処理関数」を(基本的に無名関数として)渡す。
    // この「本体となる非同期処理関数」は、成功と失敗のコールバックを受け取る。
    function(resolve, reject) {

      // そして、ajaxなどの非同期処理を実行して、
      // 結果を受けて、thenメソッドに渡されたコールバックを実行する。
      AsynchronousProcessingWrapper({
        success: function(data) { // 成功した場合
          // 成功のコールバックを実行する。
          resolve('成功1');
        },
        fail: function() { // 失敗した場合
          // 失敗のコールバックを実行する。
          reject('失敗1');
        }
      });
    }

    // resolve, rejectコールバックに値を渡した場合、
    // この値は、後続の非同期処理に渡されるため、
    // 後続の「本体となる非同期処理関数」で利用できる。
  );
};

// fetchSomething1 と同じ。
var fetchSomething2 = function(str) {

  return new Promise(function(resolve, reject) {
    AsynchronousProcessingWrapper({
      success: function(data) { // 成功した場合
        resolve(str + ' 成功2');
      },
      fail: function() { // 失敗した場合
        reject(str + ' 失敗2');
      }
    });
  });
};

fetchSomething1().then(function(rtn) {
  alert(rtn);
  return fetchSomething2(rtn);
}, function(error) {
  alert('error:' + error);
  return fetchSomething2(error);
}).then(function(rtn) {
  alert(rtn);
}, function(error) {
  alert('error:' + error);
});

developer.mozilla.orgで実行可能にしたサンプル・コード

https://developer.mozilla.org/ja/docs/Web/JavaScript/Reference/Global_Objects/Promise/then

※ ダミー非同期関数を削除した。
※ resolveをrejectに切り替えると動作を変更させることができる。

var fetchSomething1 = function() {
  return new Promise(function(resolve, reject) {
        resolve('成功1');
        //reject('失敗1');
  });
};

var fetchSomething2 = function(str) {
  return new Promise(function(resolve, reject) {
        resolve(str + ' 成功2');
        //reject(str + ' 失敗2');
  });
};

fetchSomething1().then(function(rtn) {
  alert(rtn);
  return fetchSomething2(rtn);
}, function(error) {
  alert('error:' + error);
  return fetchSomething2(error);
}).then(function(rtn) {
  alert(rtn);
}, function(error) {
  alert('error:' + error);
});

その他の機能

同期処理

並列処理

以下で、並列処理を実装できる。

エラー処理

チェーンの最後にだけ、

「失敗のPromiseオブジェクトを返す非同期処理関数」

を設定すれば、ココでエラーをまとめてキャッチできる。

参考

MDN

Qiita

HTML5Experts.jp


トップ   新規 一覧 単語検索 最終更新   ヘルプ   最終更新のRSS