javascript使用Promise對象實現(xiàn)異步編程
Promise對象是CommonJS工作組為異步編程提供的統(tǒng)一接口,是ECMAScript6中提供了對Promise的原生支持,Promise就是在未來發(fā)生的事情,使用Promise可以避免回調(diào)函數(shù)的層層嵌套,還提供了規(guī)范更加容易的對異步操作進行控制。提供了reject,resolve,then和catch等方法。
使用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(); } });
這里定義了一個回調(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進行網(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進行網(wǎng)絡(luò)請求,也可以使用Promise在瀏覽上實現(xiàn)Ajax請求。
代碼地址:https://github.com/jjz/node
相關(guān)文章
用js統(tǒng)計用戶下載網(wǎng)頁所需時間的腳本
下面的方法是個不錯的思路,建議對于js感興趣的朋友,推薦看2008-10-10詳解JS中continue關(guān)鍵字和break關(guān)鍵字的區(qū)別
在javascript中continue的作用是退出當(dāng)前次循環(huán),break的作用則是一旦當(dāng)前循環(huán)有break那么直接退出整個循環(huán)。本文將通過一些示例為大家詳細講講二者的區(qū)別,感興趣的可以了解一下2022-08-08使用?JavaScript?Promise?讀取?Github?用戶數(shù)據(jù)
這篇文章主要介紹了使用JavaScript?Promise讀取Github用戶數(shù)據(jù),文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-08-08