ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScript は Promise オブジェクトを使用して非同期プログラミングを実装します_JavaScript スキル

JavaScript は Promise オブジェクトを使用して非同期プログラミングを実装します_JavaScript スキル

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2016-05-16 15:12:35
オリジナル
1205 人が閲覧しました

Promise オブジェクトは、非同期プログラミング用に CommonJS ワーキング グループによって提供される統一インターフェイスです。これは、ECMAScript6 で提供される Promise のネイティブ サポートです。Promise を使用すると、コールバック関数の層のネストを回避できます。この仕様により、非同期操作の制御が容易になります。拒否、解決、その後、キャッチなどのメソッドを提供します。

約束を使用する

Promise は ES6 以降のネイティブ オブジェクトです。直接使用するには、Promise オブジェクトをインスタンス化するだけです。
Promise のインスタンス化:

var promise = new Promise(function (resolve, reject) {
  console.log('begin do something');
  if (Math.random() * 10.0 > 5) {
    console.log(" run success");
    resolve();
  } else {
    console.log(" run failed");
    reject();

  }
});

ログイン後にコピー

ここではコールバックメソッド関数(resolve,reject)が定義されており、成功した場合はresolveが呼び出され、失敗した場合はrejectが呼び出されます。
Promise.prototype.then は、Promise が実行された後のコールバックです。 then メソッドを使用して、resolve と拒否のコールバックをそれぞれ指定できます。

promise.then(function () {
  console.log(' resolve from promise');
}, function () {
  console.log(' reject from promise');
});
ログイン後にコピー

実行結果 1:

begin do something
 run success
 resolve from promise
ログイン後にコピー

実行結果 2:

begin do something
 run failed
 reject from promise
ログイン後にコピー

ネットワークリクエストには PROMISE を使用してください

getRequest = function (url) {
  var promise = new Promise(function (resolve, reject) {
    var request = require('request');
    request(url, function (error, respones, body) {
      if (error) {
        reject(error);
        return;
      }
      if (respones.statusCode == 200) {
        resolve(body)

      } else {
        reject(respones.status);

      }
    });
  });
  return promise;

};

getRequest("https://github.com/").then(function (result) {
  console.log(result);
}, function (error) {
  console.error('error', error);
});

ログイン後にコピー

Promise を使用してネットワーク リクエストを作成します。また、Promise を使用してブラウジング時に Ajax リクエストを実装することもできます。

コードアドレス: https://github.com/jjz/node

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート