欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript使用Promise對象實(shí)現(xiàn)異步編程

 更新時(shí)間:2016年03月01日 11:59:17   投稿:hebedich  
這篇文章主要介紹了javascript使用Promise對象實(shí)現(xiàn)異步編程的相關(guān)資料,需要的朋友可以參考下

Promise對象是CommonJS工作組為異步編程提供的統(tǒng)一接口,是ECMAScript6中提供了對Promise的原生支持,Promise就是在未來發(fā)生的事情,使用Promise可以避免回調(diào)函數(shù)的層層嵌套,還提供了規(guī)范更加容易的對異步操作進(jìn)行控制。提供了reject,resolve,then和catch等方法。

使用PROMISE

Promise是ES6之后原生的對象,我們只需要實(shí)例化Promise對象就可以直接使用。
實(shí)例化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();

  }
});

這里定義了一個(gè)回調(diào)方法function(resolve,reject),如果成功了就調(diào)用resolve,失敗了就會調(diào)用reject。
Promise.prototype.then是Promise執(zhí)行完之后的回調(diào),可以用then方法分別指定resolve和reject的回調(diào)。

promise.then(function () {
  console.log(' resolve from promise');
}, function () {
  console.log(' reject from promise');
});

執(zhí)行結(jié)果一:

begin do something
 run success
 resolve from promise

執(zhí)行結(jié)果二:

begin do something
 run failed
 reject from promise

使用PROMISE進(jìn)行網(wǎng)絡(luò)請求

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進(jìn)行網(wǎng)絡(luò)請求,也可以使用Promise在瀏覽上實(shí)現(xiàn)Ajax請求。

代碼地址:https://github.com/jjz/node

相關(guān)文章

  • 新手如何快速理解js異步編程

    新手如何快速理解js異步編程

    這篇文章主要介紹了新手如何快速理解js異步編程,異步編程從早期的 callback、事件發(fā)布\訂閱模式到 ES6 的 Promise、Generator 在到 ES2017 中 async,看似風(fēng)格迥異,但是還是有一條暗線將它們串聯(lián)在一起的,,需要的朋友可以參考下
    2019-06-06
  • 用js統(tǒng)計(jì)用戶下載網(wǎng)頁所需時(shí)間的腳本

    用js統(tǒng)計(jì)用戶下載網(wǎng)頁所需時(shí)間的腳本

    下面的方法是個(gè)不錯(cuò)的思路,建議對于js感興趣的朋友,推薦看
    2008-10-10
  • 值得收藏的八個(gè)常用的js正則表達(dá)式

    值得收藏的八個(gè)常用的js正則表達(dá)式

    這 開發(fā)中如果有input輸入框,難免就要寫正則表達(dá)式,因此在這里總結(jié)了一些常見常用的正則表達(dá)式的書寫方法,需要的朋友可以參考下
    2018-10-10
  • Javascript alert消息換行的方法

    Javascript alert消息換行的方法

    這篇文章介紹了Javascript alert消息換行的方法,有需要的朋友可以參考一下
    2013-08-08
  • typescript中高級類型Record詳解

    typescript中高級類型Record詳解

    這篇文章主要介紹了typescript中高級類型Record,ts文檔上對Record的介紹不多,但卻經(jīng)常用到,Record是一個(gè)很好用的工具類型,本文給大家詳細(xì)講解需要的朋友可以參考下
    2022-11-11
  • 利用types增強(qiáng)vscode中js代碼提示功能詳解

    利用types增強(qiáng)vscode中js代碼提示功能詳解

    這篇文章主要給大家介紹了如何增強(qiáng)vscode中js代碼提示功能的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編一起來學(xué)習(xí)學(xué)習(xí)吧。
    2017-07-07
  • 詳解JS中continue關(guān)鍵字和break關(guān)鍵字的區(qū)別

    詳解JS中continue關(guān)鍵字和break關(guān)鍵字的區(qū)別

    在javascript中continue的作用是退出當(dāng)前次循環(huán),break的作用則是一旦當(dāng)前循環(huán)有break那么直接退出整個(gè)循環(huán)。本文將通過一些示例為大家詳細(xì)講講二者的區(qū)別,感興趣的可以了解一下
    2022-08-08
  • JavaScript中set與get方法用法示例

    JavaScript中set與get方法用法示例

    這篇文章主要介紹了JavaScript中set與get方法用法,簡單描述了set與get方法的功能,并結(jié)合實(shí)例形式分析了set與get方法的具體使用技巧,需要的朋友可以參考下
    2018-08-08
  • 使用?JavaScript?Promise?讀取?Github?用戶數(shù)據(jù)

    使用?JavaScript?Promise?讀取?Github?用戶數(shù)據(jù)

    這篇文章主要介紹了使用JavaScript?Promise讀取Github用戶數(shù)據(jù),文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • 純JS代碼實(shí)現(xiàn)一鍵分享功能

    純JS代碼實(shí)現(xiàn)一鍵分享功能

    在qq空間,新浪微博,人人網(wǎng)等網(wǎng)絡(luò)平臺大家經(jīng)??梢钥吹揭绘I分享功能,那么基于js代碼是如何實(shí)現(xiàn)一鍵分享的呢?下面腳本之家小編給大家介紹js實(shí)現(xiàn)一鍵分享功能的代碼,需要的朋友參考下吧
    2016-04-04

最新評論